<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FProcedure_Function%2FOutput_parameter</id>
		<title>SQL Server/T-SQL Tutorial/Procedure Function/Output parameter - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FProcedure_Function%2FOutput_parameter"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Output_parameter&amp;action=history"/>
		<updated>2026-05-24T02:33:08Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Output_parameter&amp;diff=7071&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Output_parameter&amp;diff=7071&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:16Z</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://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Output_parameter&amp;diff=7072&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Output_parameter&amp;diff=7072&amp;oldid=prev"/>
				<updated>2010-05-26T10:25:16Z</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;== Parameter for passing value out of a procedure==&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;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; CREATE TABLE authors(&lt;br /&gt;
6&amp;gt;    au_id          varchar(11),&lt;br /&gt;
7&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
8&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
9&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
10&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
11&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
12&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
13&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
14&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
15&amp;gt; )&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert authors values(&amp;quot;1&amp;quot;,  &amp;quot;Joe&amp;quot;,   &amp;quot;Abra&amp;quot;,   &amp;quot;111 111-1111&amp;quot;, &amp;quot;6 St.&amp;quot;, &amp;quot;Berkeley&amp;quot;,  &amp;quot;CA&amp;quot;, &amp;quot;11111&amp;quot;, 1)&lt;br /&gt;
2&amp;gt; insert authors values(&amp;quot;2&amp;quot;,  &amp;quot;Jack&amp;quot;,  &amp;quot;Majo&amp;quot;,   &amp;quot;222 222-2222&amp;quot;, &amp;quot;3 St.&amp;quot;, &amp;quot;Oakland&amp;quot; ,  &amp;quot;CA&amp;quot;, &amp;quot;22222&amp;quot;, 1)&lt;br /&gt;
3&amp;gt; insert authors values(&amp;quot;3&amp;quot;,  &amp;quot;Pink&amp;quot;,  &amp;quot;Cherry&amp;quot;, &amp;quot;333 333-3333&amp;quot;, &amp;quot;5 Ln.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;33333&amp;quot;, 1)&lt;br /&gt;
4&amp;gt; insert authors values(&amp;quot;4&amp;quot;,  &amp;quot;Blue&amp;quot;,  &amp;quot;Albert&amp;quot;, &amp;quot;444 444-4444&amp;quot;, &amp;quot;7 Av.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;44444&amp;quot;, 1)&lt;br /&gt;
5&amp;gt; insert authors values(&amp;quot;5&amp;quot;,  &amp;quot;Red&amp;quot;,   &amp;quot;Anne&amp;quot;,   &amp;quot;555 555-5555&amp;quot;, &amp;quot;6 Av.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;55555&amp;quot;, 1)&lt;br /&gt;
6&amp;gt; insert authors values(&amp;quot;6&amp;quot;,  &amp;quot;Black&amp;quot;, &amp;quot;Michel&amp;quot;, &amp;quot;666 666-6666&amp;quot;, &amp;quot;3 Pl.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;66666&amp;quot;, 1)&lt;br /&gt;
7&amp;gt; insert authors values(&amp;quot;7&amp;quot;,  &amp;quot;White&amp;quot;, &amp;quot;Sylvia&amp;quot;, &amp;quot;777 777-7777&amp;quot;, &amp;quot;1 Pl.&amp;quot;, &amp;quot;Rockville&amp;quot;, &amp;quot;MD&amp;quot;, &amp;quot;77777&amp;quot;, 1)&lt;br /&gt;
8&amp;gt; insert authors values(&amp;quot;8&amp;quot;,  &amp;quot;Yellow&amp;quot;,&amp;quot;Heather&amp;quot;,&amp;quot;888 888-8888&amp;quot;, &amp;quot;3 Pu&amp;quot;,  &amp;quot;Vacaville&amp;quot;, &amp;quot;CA&amp;quot;, &amp;quot;88888&amp;quot;, 0)&lt;br /&gt;
9&amp;gt; insert authors values(&amp;quot;9&amp;quot;,  &amp;quot;Gold&amp;quot;,  &amp;quot;Dep&amp;quot;,    &amp;quot;999 999-9999&amp;quot;, &amp;quot;5 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;99999&amp;quot;, 0)&lt;br /&gt;
10&amp;gt; insert authors values(&amp;quot;10&amp;quot;, &amp;quot;Siler&amp;quot;, &amp;quot;Dean&amp;quot;,   &amp;quot;000 000-0000&amp;quot;, &amp;quot;4 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;00000&amp;quot;, 1)&lt;br /&gt;
11&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 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 PROC count_tables @authorcount int OUTPUT,&lt;br /&gt;
3&amp;gt; @titlecount int OUTPUT&lt;br /&gt;
4&amp;gt; AS&lt;br /&gt;
5&amp;gt; SELECT * FROM authors&lt;br /&gt;
6&amp;gt; SET @authorcount=@@ROWCOUNT&lt;br /&gt;
7&amp;gt; SET @titlecount=@@ROWCOUNT&lt;br /&gt;
8&amp;gt; RETURN(0)&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; DECLARE @a_count int, @t_count int&lt;br /&gt;
3&amp;gt; EXEC count_tables @a_count OUTPUT, @t_count OUTPUT&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
au_id       au_lname                                 au_fname             phone        address                                  city                 state zip   contract&lt;br /&gt;
----------- ---------------------------------------- -------------------- ------------ ---------------------------------------- -------------------- ----- ----- --------&lt;br /&gt;
1           Joe                                      Abra                 111 111-1111 6 St.                                    Berkeley             CA    11111        1&lt;br /&gt;
2           Jack                                     Majo                 222 222-2222 3 St.                                    Oakland              CA    22222        1&lt;br /&gt;
3           Pink                                     Cherry               333 333-3333 5 Ln.                                    Vancouver            BC    33333        1&lt;br /&gt;
4           Blue                                     Albert               444 444-4444 7 Av.                                    Vancouver            BC    44444        1&lt;br /&gt;
5           Red                                      Anne                 555 555-5555 6 Av.                                    Regina               SK    55555        1&lt;br /&gt;
6           Black                                    Michel               666 666-6666 3 Pl.                                    Regina               SK    66666        1&lt;br /&gt;
7           White                                    Sylvia               777 777-7777 1 Pl.                                    Rockville            MD    77777        1&lt;br /&gt;
8           Yellow                                   Heather              888 888-8888 3 Pu                                     Vacaville            CA    88888        0&lt;br /&gt;
9           Gold                                     Dep                  999 999-9999 5 Av.                                    Oakland              CA    99999        0&lt;br /&gt;
10          Siler                                    Dean                 000 000-0000 4 Av.                                    Oakland              CA    00000        1&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROC count_tables;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; drop table authors;&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Recursive procedure with output parameter==&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;
6&amp;gt;    CREATE PROC spTriangular&lt;br /&gt;
7&amp;gt;    @ValueIn int,&lt;br /&gt;
8&amp;gt;    @ValueOut int OUTPUT&lt;br /&gt;
9&amp;gt;    AS&lt;br /&gt;
10&amp;gt;    DECLARE @InWorking int&lt;br /&gt;
11&amp;gt;    DECLARE @OutWorking int&lt;br /&gt;
12&amp;gt;    IF @ValueIn != 1&lt;br /&gt;
13&amp;gt;    BEGIN&lt;br /&gt;
14&amp;gt;            SELECT @InWorking = @ValueIn - 1&lt;br /&gt;
15&amp;gt;            EXEC spTriangular @InWorking, @OutWorking OUTPUT&lt;br /&gt;
16&amp;gt;&lt;br /&gt;
17&amp;gt;            SELECT @ValueOut = @ValueIn + @OutWorking&lt;br /&gt;
18&amp;gt;    END&lt;br /&gt;
19&amp;gt;    ELSE&lt;br /&gt;
20&amp;gt;    BEGIN&lt;br /&gt;
21&amp;gt;            SELECT @ValueOut = 1&lt;br /&gt;
22&amp;gt;    END&lt;br /&gt;
23&amp;gt;    RETURN&lt;br /&gt;
24&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    DECLARE @WorkingOut int&lt;br /&gt;
3&amp;gt;    DECLARE @WorkingIn int&lt;br /&gt;
4&amp;gt;    SELECT @WorkingIn = 5&lt;br /&gt;
5&amp;gt;    EXEC spTriangular @WorkingIn, @WorkingOut OUTPUT&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt;    PRINT CAST(@WorkingIn AS varchar) + &amp;quot; Triangular is &amp;quot; + CAST(@WorkingOut AS varchar)&lt;br /&gt;
8&amp;gt;    GO&lt;br /&gt;
5 Triangular is 15&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop PROC spTriangular;&lt;br /&gt;
3&amp;gt;    GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Stored procedure returning value using an Output parameter==&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;
7&amp;gt;&lt;br /&gt;
8&amp;gt; CREATE PROCEDURE spCalculateOutput&lt;br /&gt;
9&amp;gt;   @Value1      Float&lt;br /&gt;
10&amp;gt;  , @Value2      Float&lt;br /&gt;
11&amp;gt;  , @Operator    Char(10)&lt;br /&gt;
12&amp;gt;  , @Result      Float     Output&lt;br /&gt;
13&amp;gt; As&lt;br /&gt;
14&amp;gt;  IF @Operator = &amp;quot;+&amp;quot;&lt;br /&gt;
15&amp;gt;     SET @Result = @Value1 + @Value2&lt;br /&gt;
16&amp;gt;  ELSE IF @Operator = &amp;quot;-&amp;quot;&lt;br /&gt;
17&amp;gt;     SET @Result = @Value1 - @Value2&lt;br /&gt;
18&amp;gt;  ELSE IF @Operator = &amp;quot;*&amp;quot;&lt;br /&gt;
19&amp;gt;     SET @Result = @Value1 * @Value2&lt;br /&gt;
20&amp;gt;  ELSE IF @Operator = &amp;quot;/&amp;quot;&lt;br /&gt;
21&amp;gt;     SET @Result = @Value1 / @Value2&lt;br /&gt;
22&amp;gt;&lt;br /&gt;
23&amp;gt; -- Declare a variable for the result value&lt;br /&gt;
24&amp;gt; Declare @Out Float&lt;br /&gt;
25&amp;gt; -- Execute the procedure &amp;amp; assign the result&lt;br /&gt;
26&amp;gt; Execute spCalculate_Output 123, 456, &amp;quot;+&amp;quot;&lt;br /&gt;
27&amp;gt; -- Print the result value&lt;br /&gt;
28&amp;gt; Print @Out&lt;br /&gt;
29&amp;gt;&lt;br /&gt;
30&amp;gt;&lt;br /&gt;
31&amp;gt; drop procedure spCalculateOutput;&lt;br /&gt;
32&amp;gt; GO&lt;br /&gt;
Cannot add rows to sysdepends for the current object because it depends on the missing object &amp;quot;spCalculate_Output&amp;quot;. The object will still be created.&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>