<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL%2FTransact_SQL%2FTable_Variable</id>
		<title>SQL Server/T-SQL/Transact SQL/Table Variable - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL%2FTransact_SQL%2FTable_Variable"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Table_Variable&amp;action=history"/>
		<updated>2026-04-04T13:56:59Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Table_Variable&amp;diff=5718&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Table_Variable&amp;diff=5718&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:06Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 13:46, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Table_Variable&amp;diff=5719&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Table_Variable&amp;diff=5719&amp;oldid=prev"/>
				<updated>2010-05-26T10:20:12Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Creating Inline User-Defined Functions==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE employee(&lt;br /&gt;
7&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
8&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
9&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
10&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
11&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
12&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
13&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
14&amp;gt;    managerid   INTEGER&lt;br /&gt;
15&amp;gt; );&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE FUNCTION dbo.udf_employee(@EmployeeID int)&lt;br /&gt;
4&amp;gt; RETURNS TABLE&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt; RETURN (SELECT ID, first_name FROM Employee)&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; SELECT ID, first_name FROM dbo.udf_employee(2)&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; drop function dbo.udf_employee&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
ID          first_name&lt;br /&gt;
----------- ----------&lt;br /&gt;
          1 Jason&lt;br /&gt;
          2 Alison&lt;br /&gt;
          3 James&lt;br /&gt;
          4 Celia&lt;br /&gt;
          5 Robert&lt;br /&gt;
          6 Linda&lt;br /&gt;
          7 David&lt;br /&gt;
          8 James&lt;br /&gt;
          9 Joan&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Define table variable==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
1&amp;gt; create table employee(&lt;br /&gt;
2&amp;gt;     ID          int,&lt;br /&gt;
3&amp;gt;     name        nvarchar (10),&lt;br /&gt;
4&amp;gt;     salary      int,&lt;br /&gt;
5&amp;gt;     start_date  datetime,&lt;br /&gt;
6&amp;gt;     city        nvarchar (10),&lt;br /&gt;
7&amp;gt;     region      char (1))&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
3&amp;gt;               values (1,  &amp;quot;Jason&amp;quot;, 40420,  &amp;quot;02/01/94&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (2,  &amp;quot;Robert&amp;quot;,14420,  &amp;quot;01/02/95&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (3,  &amp;quot;Celia&amp;quot;, 24020,  &amp;quot;12/03/96&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (4,  &amp;quot;Linda&amp;quot;, 40620,  &amp;quot;11/04/97&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (5,  &amp;quot;David&amp;quot;, 80026,  &amp;quot;10/05/98&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (6,  &amp;quot;James&amp;quot;, 70060,  &amp;quot;09/06/99&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (7,  &amp;quot;Alison&amp;quot;,90620,  &amp;quot;08/07/00&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (8,  &amp;quot;Chris&amp;quot;, 26020,  &amp;quot;07/08/01&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (9,  &amp;quot;Mary&amp;quot;,  60020,  &amp;quot;06/09/02&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W&lt;br /&gt;
          2 Robert           14420 1995-01-02 00:00:00.000 Vancouver  N&lt;br /&gt;
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W&lt;br /&gt;
          4 Linda            40620 1997-11-04 00:00:00.000 New York   N&lt;br /&gt;
          5 David            80026 1998-10-05 00:00:00.000 Vancouver  W&lt;br /&gt;
          6 James            70060 1999-09-06 00:00:00.000 Toronto    N&lt;br /&gt;
          7 Alison           90620 2000-08-07 00:00:00.000 New York   W&lt;br /&gt;
          8 Chris            26020 2001-07-08 00:00:00.000 Vancouver  N&lt;br /&gt;
          9 Mary             60020 2002-06-09 00:00:00.000 Toronto    W&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; DECLARE @MyTable Table (&lt;br /&gt;
4&amp;gt; OrderID         int,&lt;br /&gt;
5&amp;gt; Name            char (50)&lt;br /&gt;
6&amp;gt; )&lt;br /&gt;
7&amp;gt;&lt;br /&gt;
8&amp;gt; INSERT INTO @MyTable&lt;br /&gt;
9&amp;gt;    SELECT ID, Name&lt;br /&gt;
10&amp;gt;    FROM Employee&lt;br /&gt;
11&amp;gt;    WHERE ID BETWEEN 1 AND 10&lt;br /&gt;
12&amp;gt;&lt;br /&gt;
13&amp;gt; SELECT * FROM @MyTable&lt;br /&gt;
14&amp;gt;&lt;br /&gt;
15&amp;gt;&lt;br /&gt;
16&amp;gt; drop table employee&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
OrderID     Name&lt;br /&gt;
----------- --------------------------------------------------&lt;br /&gt;
          1 Jason&lt;br /&gt;
          2 Robert&lt;br /&gt;
          3 Celia&lt;br /&gt;
          4 Linda&lt;br /&gt;
          5 David&lt;br /&gt;
          6 James&lt;br /&gt;
          7 Alison&lt;br /&gt;
          8 Chris&lt;br /&gt;
          9 Mary&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Function to pass an array==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
4&amp;gt; CREATE FUNCTION dbo.udf_ParseArray( @StringArray varchar(max),@Delimiter char(1) ,@MinRowSelect int,@MaxRowSelect int)&lt;br /&gt;
5&amp;gt; RETURNS @StringArrayTable TABLE (RowNum int IDENTITY(1,1), Val varchar(50))&lt;br /&gt;
6&amp;gt; AS&lt;br /&gt;
7&amp;gt; BEGIN&lt;br /&gt;
8&amp;gt;     DECLARE @Delimiter_position int&lt;br /&gt;
9&amp;gt;     IF RIGHT(@StringArray,1) != @Delimiter&lt;br /&gt;
10&amp;gt;         SET @StringArray = @StringArray + @Delimiter&lt;br /&gt;
11&amp;gt;         WHILE CHARINDEX(@Delimiter, @StringArray) &amp;lt;&amp;gt; 0&lt;br /&gt;
12&amp;gt;         BEGIN&lt;br /&gt;
13&amp;gt;             SELECT @Delimiter_position = CHARINDEX(@Delimiter, @StringArray)&lt;br /&gt;
14&amp;gt;             INSERT @StringArrayTable VALUES (left(@StringArray, @Delimiter_position - 1))&lt;br /&gt;
15&amp;gt;             SELECT @StringArray = stuff(@StringArray, 1, @Delimiter_position, &amp;quot;&amp;quot;)&lt;br /&gt;
16&amp;gt;         END&lt;br /&gt;
17&amp;gt;         DELETE @StringArrayTable&lt;br /&gt;
18&amp;gt;         WHERE RowNum &amp;lt; @MinRowSelect OR RowNum &amp;gt; @MaxRowSelect&lt;br /&gt;
19&amp;gt;     RETURN&lt;br /&gt;
20&amp;gt; END&lt;br /&gt;
21&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; SELECT RowNum, Val&lt;br /&gt;
3&amp;gt; FROM udf_ParseArray(&amp;quot;A,B,C,D,E,F,G&amp;quot;, &amp;quot;,&amp;quot;, 3, 5)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
RowNum      Val&lt;br /&gt;
----------- --------------------------------------------------&lt;br /&gt;
          3 C&lt;br /&gt;
          4 D&lt;br /&gt;
          5 E&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop function dbo.udf_ParseArray&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Legal custorderdetails Inline Table-Valued Function==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE employee(&lt;br /&gt;
7&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
8&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
9&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
10&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
11&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
12&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
13&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
14&amp;gt;    managerid   INTEGER&lt;br /&gt;
15&amp;gt; );&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE FUNCTION dbo.custorderdetails(&lt;br /&gt;
4&amp;gt;   @custid char(5)&lt;br /&gt;
5&amp;gt; )&lt;br /&gt;
6&amp;gt; RETURNS TABLE&lt;br /&gt;
7&amp;gt; AS&lt;br /&gt;
8&amp;gt; RETURN SELECT&lt;br /&gt;
9&amp;gt;          OD.ID,&lt;br /&gt;
10&amp;gt;          OD.Salary&lt;br /&gt;
11&amp;gt;        FROM&lt;br /&gt;
12&amp;gt;            Employee          AS OD&lt;br /&gt;
13&amp;gt;        WHERE&lt;br /&gt;
14&amp;gt;            OD.ID = @custid&lt;br /&gt;
15&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from dbo.custorderdetails(&amp;quot;1&amp;quot;)&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; drop function dbo.custorderdetails&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
ID          Salary&lt;br /&gt;
----------- ------------&lt;br /&gt;
          1      5890.00&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; drop table employee;&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use return statement to return a table from a function==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TABLE Employees (&lt;br /&gt;
4&amp;gt;      EmployeeID int NOT NULL ,&lt;br /&gt;
5&amp;gt;      LastName nvarchar (20) NOT NULL ,&lt;br /&gt;
6&amp;gt;      FirstName nvarchar (10) NOT NULL ,&lt;br /&gt;
7&amp;gt;      Title nvarchar (30) NULL ,&lt;br /&gt;
8&amp;gt;      TitleOfCourtesy nvarchar (25) NULL ,&lt;br /&gt;
9&amp;gt;      BirthDate datetime NULL ,&lt;br /&gt;
10&amp;gt;     HireDate datetime NULL ,&lt;br /&gt;
11&amp;gt;     Address nvarchar (60) NULL ,&lt;br /&gt;
12&amp;gt;     City nvarchar (15) NULL ,&lt;br /&gt;
13&amp;gt;     Region nvarchar (15) NULL ,&lt;br /&gt;
14&amp;gt;     PostalCode nvarchar (10) NULL ,&lt;br /&gt;
15&amp;gt;     Country nvarchar (15) NULL ,&lt;br /&gt;
16&amp;gt;     HomePhone nvarchar (24) NULL ,&lt;br /&gt;
17&amp;gt;     Extension nvarchar (4) NULL ,&lt;br /&gt;
18&amp;gt;     Photo image NULL ,&lt;br /&gt;
19&amp;gt;     Notes ntext NULL ,&lt;br /&gt;
20&amp;gt;     ReportsTo int NULL ,&lt;br /&gt;
21&amp;gt;     PhotoPath nvarchar (255) NULL&lt;br /&gt;
22&amp;gt;&lt;br /&gt;
23&amp;gt; )&lt;br /&gt;
24&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE TABLE RegionPlace&lt;br /&gt;
5&amp;gt;      (RegionID nvarchar (20) NOT NULL ,&lt;br /&gt;
6&amp;gt;      TerritoryDescription nchar (50) NOT NULL ,&lt;br /&gt;
7&amp;gt;         RegionID int NOT NULL&lt;br /&gt;
8&amp;gt; )&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; Insert Into RegionPlace Values (&amp;quot;01581&amp;quot;,&amp;quot;Westboro&amp;quot;,1)&lt;br /&gt;
3&amp;gt; Insert Into RegionPlace Values (&amp;quot;01730&amp;quot;,&amp;quot;Bedford&amp;quot;,1)&lt;br /&gt;
4&amp;gt; Insert Into RegionPlace Values (&amp;quot;01833&amp;quot;,&amp;quot;Georgetow&amp;quot;,1)&lt;br /&gt;
5&amp;gt; Insert Into RegionPlace Values (&amp;quot;95060&amp;quot;,&amp;quot;Santa Cruz&amp;quot;,2)&lt;br /&gt;
6&amp;gt; Insert Into RegionPlace Values (&amp;quot;98004&amp;quot;,&amp;quot;Bellevue&amp;quot;,2)&lt;br /&gt;
7&amp;gt; Insert Into RegionPlace Values (&amp;quot;98052&amp;quot;,&amp;quot;Redmond&amp;quot;,2)&lt;br /&gt;
8&amp;gt; Insert Into RegionPlace Values (&amp;quot;98104&amp;quot;,&amp;quot;Seattle&amp;quot;,2)&lt;br /&gt;
9&amp;gt; Go&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; CREATE TABLE EmployeeRegion&lt;br /&gt;
2&amp;gt;      (EmployeeID int NOT NULL,&lt;br /&gt;
3&amp;gt;       RegionID nvarchar (20) NOT NULL&lt;br /&gt;
4&amp;gt; )&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; Insert Into EmployeeRegion Values (1,&amp;quot;06897&amp;quot;)&lt;br /&gt;
3&amp;gt; Insert Into EmployeeRegion Values (1,&amp;quot;19713&amp;quot;)&lt;br /&gt;
4&amp;gt; Insert Into EmployeeRegion Values (9,&amp;quot;48084&amp;quot;)&lt;br /&gt;
5&amp;gt; Insert Into EmployeeRegion Values (9,&amp;quot;48304&amp;quot;)&lt;br /&gt;
6&amp;gt; Insert Into EmployeeRegion Values (9,&amp;quot;55113&amp;quot;)&lt;br /&gt;
7&amp;gt; Insert Into EmployeeRegion Values (9,&amp;quot;55439&amp;quot;)&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE FUNCTION dbo.udf_EmpRegionPlaceTAB (&lt;br /&gt;
3&amp;gt;     @EmployeeID int&lt;br /&gt;
4&amp;gt; )   RETURNS TABLE&lt;br /&gt;
5&amp;gt; AS RETURN&lt;br /&gt;
6&amp;gt; SELECT TOP 100 PERCENT WITH TIES&lt;br /&gt;
7&amp;gt;        et.RegionID&lt;br /&gt;
8&amp;gt;      , t.TerritoryDescription as [Territory]&lt;br /&gt;
9&amp;gt;      , t.RegionID&lt;br /&gt;
10&amp;gt;     FROM EmployeeRegion et&lt;br /&gt;
11&amp;gt;          LEFT OUTER JOIN RegionPlace t&lt;br /&gt;
12&amp;gt;              ON et.RegionID = t.RegionID&lt;br /&gt;
13&amp;gt;     WHERE et.EmployeeID = @EmployeeID&lt;br /&gt;
14&amp;gt;     ORDER BY t.TerritoryDescription&lt;br /&gt;
15&amp;gt;&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; DECLARE @EmpID int&lt;br /&gt;
3&amp;gt; SELECT @EmpID = EmployeeID&lt;br /&gt;
4&amp;gt;     FROM Employees&lt;br /&gt;
5&amp;gt;     WHERE FirstName = &amp;quot;Andrew&amp;quot; and LastName = &amp;quot;Fuller&amp;quot;&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; SELECT * FROM udf_EmpRegionPlaceTAB(@EmpID)&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
RegionID          Territory                                          RegionID&lt;br /&gt;
-------------------- -------------------------------------------------- -----------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; drop FUNCTION dbo.udf_EmpRegionPlaceTAB;&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&amp;gt; drop table EmployeeRegion;&lt;br /&gt;
2&amp;gt; drop table RegionPlace;&lt;br /&gt;
3&amp;gt; drop table Employees;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>