<?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%2FProcedure</id>
		<title>SQL Server/T-SQL Tutorial/Procedure Function/Procedure - История изменений</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%2FProcedure"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Procedure&amp;action=history"/>
		<updated>2026-05-24T03:39:00Z</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/Procedure&amp;diff=7047&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/Procedure&amp;diff=7047&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/Procedure&amp;diff=7048&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/Procedure&amp;diff=7048&amp;oldid=prev"/>
				<updated>2010-05-26T10:25:08Z</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;== calls the 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;
10&amp;gt; create table Billings (&lt;br /&gt;
11&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
12&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
13&amp;gt;     BillingDate        datetime,&lt;br /&gt;
14&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
15&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
16&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
17&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
18&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
19&amp;gt;&lt;br /&gt;
20&amp;gt; );&lt;br /&gt;
21&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; INSERT INTO Billings VALUES (1, 1, &amp;quot;2005-01-22&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (2, 2, &amp;quot;2001-02-21&amp;quot;, 165, 1,&amp;quot;2002-02-22&amp;quot;,123,321.);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (3, 3, &amp;quot;2003-05-02&amp;quot;, 165, 1,&amp;quot;2005-04-12&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (4, 4, &amp;quot;1999-03-12&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (5, 5, &amp;quot;2000-04-23&amp;quot;, 165, 1,&amp;quot;2005-04-17&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (6, 6, &amp;quot;2001-06-14&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (7, 7, &amp;quot;2002-07-15&amp;quot;, 165, 1,&amp;quot;2005-04-19&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (8, 8, &amp;quot;2003-08-16&amp;quot;, 165, 1,&amp;quot;2005-04-20&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (9, 9, &amp;quot;2004-09-17&amp;quot;, 165, 1,&amp;quot;2005-04-21&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (0, 0, &amp;quot;2005-10-18&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&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;&lt;br /&gt;
3&amp;gt; CREATE PROC spInsertBilling&lt;br /&gt;
4&amp;gt;        @BankerID    int,           @BillingNumber  varchar(50),&lt;br /&gt;
5&amp;gt;        @BillingDate smalldatetime, @BillingTotal   money,&lt;br /&gt;
6&amp;gt;        @TermsID     int,           @BillingDueDate smalldatetime&lt;br /&gt;
7&amp;gt; AS&lt;br /&gt;
8&amp;gt; IF EXISTS(SELECT * FROM Billings WHERE BankerID = @BankerID)&lt;br /&gt;
9&amp;gt;     BEGIN&lt;br /&gt;
10&amp;gt;         INSERT Billings (BankerID)&lt;br /&gt;
11&amp;gt;         VALUES (@BankerID)&lt;br /&gt;
12&amp;gt;     END&lt;br /&gt;
13&amp;gt; ELSE&lt;br /&gt;
14&amp;gt;     BEGIN&lt;br /&gt;
15&amp;gt;         RAISERROR(&amp;quot;Not a valid BankerID!&amp;quot;,1,1)&lt;br /&gt;
16&amp;gt;         RETURN -100&lt;br /&gt;
17&amp;gt;     END&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; DECLARE @ReturnVar int&lt;br /&gt;
4&amp;gt; EXEC @ReturnVar = spInsertBilling&lt;br /&gt;
5&amp;gt;      799,&amp;quot;ZXK-799&amp;quot;,&amp;quot;2002-07-01&amp;quot;,299.95,1,&amp;quot;2001-08-01&amp;quot;&lt;br /&gt;
6&amp;gt; PRINT &amp;quot;Return code was: &amp;quot; + CONVERT(varchar,@ReturnVar)&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
Not a valid BankerID!&lt;br /&gt;
Return code was: -100&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROC spInsertBilling;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Billings;&lt;br /&gt;
4&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;
== Declare a variable in 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;
4&amp;gt; CREATE TABLE Product(&lt;br /&gt;
5&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
6&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
7&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
8&amp;gt;      Color                   nvarchar(15)       NULL,&lt;br /&gt;
9&amp;gt;      StandardCost            money              NOT NULL,&lt;br /&gt;
10&amp;gt;      Size                    nvarchar(5)        NULL,&lt;br /&gt;
11&amp;gt;      Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
12&amp;gt;      ProductLine             nchar(20)           NULL,&lt;br /&gt;
13&amp;gt;      SellStartDate           datetime           NOT NULL,&lt;br /&gt;
14&amp;gt;      SellEndDate             datetime           NULL&lt;br /&gt;
15&amp;gt;  )&lt;br /&gt;
16&amp;gt;  GO&lt;br /&gt;
1&amp;gt; insert into Product values(1,&amp;quot;Product A&amp;quot;, &amp;quot;1&amp;quot;,&amp;quot;Red&amp;quot;,123.123,&amp;quot;1&amp;quot;,1,&amp;quot;ProductLine A&amp;quot;,&amp;quot;1999-03-22&amp;quot;,&amp;quot;2000-03-22&amp;quot;);&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;&lt;br /&gt;
3&amp;gt; insert into Product values(2,&amp;quot;Product B&amp;quot;, &amp;quot;2&amp;quot;,&amp;quot;Yellow&amp;quot;,234.234,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine B&amp;quot;,&amp;quot;2000-03-22&amp;quot;,&amp;quot;2001-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(3,&amp;quot;Product C&amp;quot;, &amp;quot;3&amp;quot;,&amp;quot;Pink&amp;quot;,345.345,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine V&amp;quot;,&amp;quot;2001-09-22&amp;quot;,&amp;quot;2006-02-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(4,&amp;quot;Product D&amp;quot;, &amp;quot;4&amp;quot;,&amp;quot;White&amp;quot;,456.456,&amp;quot;1&amp;quot;,4,&amp;quot;ProductLine D&amp;quot;,&amp;quot;2002-08-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(5,&amp;quot;Product E&amp;quot;, &amp;quot;5&amp;quot;,&amp;quot;Black&amp;quot;,567.567,&amp;quot;1&amp;quot;,5,&amp;quot;ProductLine E&amp;quot;,&amp;quot;2003-01-22&amp;quot;,&amp;quot;2003-04-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(6,&amp;quot;Product F&amp;quot;, &amp;quot;6&amp;quot;,&amp;quot;Blue&amp;quot;,678.678,&amp;quot;1&amp;quot;,6,&amp;quot;ProductLine W&amp;quot;,&amp;quot;2004-02-22&amp;quot;,&amp;quot;2005-05-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(7,&amp;quot;Product G&amp;quot;, &amp;quot;7&amp;quot;,&amp;quot;Drak&amp;quot;,789.789,&amp;quot;1&amp;quot;,7,&amp;quot;ProductLine Q&amp;quot;,&amp;quot;2005-03-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(8,&amp;quot;Product H&amp;quot;, &amp;quot;8&amp;quot;,&amp;quot;Gray&amp;quot;,234.123,&amp;quot;1&amp;quot;,8,&amp;quot;ProductLine F&amp;quot;,&amp;quot;2006-04-22&amp;quot;,&amp;quot;2006-09-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(9,&amp;quot;Product I&amp;quot;, &amp;quot;9&amp;quot;,&amp;quot;Red&amp;quot;,543.123,&amp;quot;1&amp;quot;,9,&amp;quot;ProductLine R&amp;quot;,&amp;quot;2007-05-22&amp;quot;,&amp;quot;2008-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(0,&amp;quot;Product J&amp;quot;, &amp;quot;0&amp;quot;,&amp;quot;Gold&amp;quot;,765.123,&amp;quot;1&amp;quot;,0,&amp;quot;ProductLine J&amp;quot;,&amp;quot;2008-06-22&amp;quot;,&amp;quot;2009-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&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;&lt;br /&gt;
5&amp;gt; CREATE PROCEDURE spProductCountBySubCategory&lt;br /&gt;
6&amp;gt;   @SubID Int&lt;br /&gt;
7&amp;gt; AS&lt;br /&gt;
8&amp;gt;   DECLARE @Out Int&lt;br /&gt;
9&amp;gt;   SELECT @Out = Count(*)&lt;br /&gt;
10&amp;gt;   FROM Product&lt;br /&gt;
11&amp;gt;   WHERE ProductID = @SubID&lt;br /&gt;
12&amp;gt;  RETURN @Out&lt;br /&gt;
13&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;&lt;br /&gt;
5&amp;gt; drop PROCEDURE spProductCountBySubCategory;&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Product;&lt;br /&gt;
4&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;
== Encrypting a Stored 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;
4&amp;gt;&lt;br /&gt;
5&amp;gt; CREATE TABLE employee(&lt;br /&gt;
6&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
7&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
8&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
9&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
10&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
11&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
12&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
13&amp;gt;    managerid   INTEGER&lt;br /&gt;
14&amp;gt; );&lt;br /&gt;
15&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 PROCEDURE usp_employee&lt;br /&gt;
4&amp;gt; WITH ENCRYPTION&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt; SELECT ID, first_name&lt;br /&gt;
7&amp;gt; FROM employee&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; exec usp_employee&lt;br /&gt;
3&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 procedure usp_employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table employee;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Filtering for Null Values with a Stored 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;
4&amp;gt;&lt;br /&gt;
5&amp;gt; create table Bankers(&lt;br /&gt;
6&amp;gt;    BankerID             Integer,&lt;br /&gt;
7&amp;gt;    BankerName           VARCHAR(20),&lt;br /&gt;
8&amp;gt;    BankerContactLName   VARCHAR(20),&lt;br /&gt;
9&amp;gt;    BankerContactFName   VARCHAR(20),&lt;br /&gt;
10&amp;gt;    BankerCity           VARCHAR(20),&lt;br /&gt;
11&amp;gt;    BankerState          VARCHAR(20),&lt;br /&gt;
12&amp;gt;    BankerZipCode        VARCHAR(20),&lt;br /&gt;
13&amp;gt;    BankerPhone          VARCHAR(20)&lt;br /&gt;
14&amp;gt; )&lt;br /&gt;
15&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into Bankers values (1, &amp;quot;ABC Inc.&amp;quot;,&amp;quot;Joe&amp;quot;,&amp;quot;Smith&amp;quot;,&amp;quot;Vancouver&amp;quot;,&amp;quot;BC&amp;quot;,&amp;quot;11111&amp;quot;,&amp;quot;111-111-1111&amp;quot;);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (2, &amp;quot;DEF Inc.&amp;quot;,&amp;quot;Red&amp;quot;,&amp;quot;Rice&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;DE&amp;quot;,&amp;quot;22222&amp;quot;,&amp;quot;222-222-2222&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (3, &amp;quot;HJI Inc.&amp;quot;,&amp;quot;Kit&amp;quot;,&amp;quot;Cat&amp;quot;,  &amp;quot;Paris&amp;quot;,    &amp;quot;CA&amp;quot;,&amp;quot;33333&amp;quot;,&amp;quot;333-333-3333&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (4, &amp;quot;QWE Inc.&amp;quot;,&amp;quot;Git&amp;quot;,&amp;quot;Black&amp;quot;,&amp;quot;Regina&amp;quot;,   &amp;quot;ER&amp;quot;,&amp;quot;44444&amp;quot;,&amp;quot;444-444-4444&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (5, &amp;quot;RTY Inc.&amp;quot;,&amp;quot;Wil&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Toronto&amp;quot;,  &amp;quot;YU&amp;quot;,&amp;quot;55555&amp;quot;,&amp;quot;555-555-5555&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (6, &amp;quot;YUI Inc.&amp;quot;,&amp;quot;Ted&amp;quot;,&amp;quot;Larry&amp;quot;,&amp;quot;Calgary&amp;quot;,  &amp;quot;TY&amp;quot;,&amp;quot;66666&amp;quot;,&amp;quot;666-666-6666&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (7, &amp;quot;OIP Inc.&amp;quot;,&amp;quot;Yam&amp;quot;,&amp;quot;Act&amp;quot;,  &amp;quot;San Franc&amp;quot;,&amp;quot;FG&amp;quot;,&amp;quot;77777&amp;quot;,&amp;quot;777-777-7777&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (8, &amp;quot;SAD Inc.&amp;quot;,&amp;quot;Hit&amp;quot;,&amp;quot;Eat&amp;quot;,  &amp;quot;Orland&amp;quot;,   &amp;quot;PO&amp;quot;,&amp;quot;88888&amp;quot;,&amp;quot;888-888-8888&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (9, &amp;quot;DFG Inc.&amp;quot;,&amp;quot;Sad&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Wisler&amp;quot;,   &amp;quot;PL&amp;quot;,&amp;quot;99999&amp;quot;,&amp;quot;999-999-9999&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (0, &amp;quot;GHJ Inc.&amp;quot;,&amp;quot;Bit&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Ticker&amp;quot;,   &amp;quot;MN&amp;quot;,&amp;quot;00000&amp;quot;,&amp;quot;000-000-0000&amp;quot;);&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;&lt;br /&gt;
3&amp;gt; CREATE PROCEDURE usp_SalesPersonInATerritoryOrNot&lt;br /&gt;
4&amp;gt; @TID int = NULL&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt; IF @TID IS NOT NULL&lt;br /&gt;
7&amp;gt;     SELECT BankerName&lt;br /&gt;
8&amp;gt;     FROM Bankers&lt;br /&gt;
9&amp;gt;     WHERE BankerID = @TID&lt;br /&gt;
10&amp;gt; ELSE&lt;br /&gt;
11&amp;gt;     SELECT BankerName&lt;br /&gt;
12&amp;gt;     FROM Bankers&lt;br /&gt;
13&amp;gt;     WHERE BankerID IS NULL&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; EXEC usp_SalesPersonInATerritoryOrNot 1&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
BankerName&lt;br /&gt;
--------------------&lt;br /&gt;
ABC Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; EXEC usp_SalesPersonInATerritoryOrNot NULL&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
BankerName&lt;br /&gt;
--------------------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt; EXEC usp_SalesPersonInATerritoryOrNot&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
BankerName&lt;br /&gt;
--------------------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROCEDURE usp_SalesPersonInATerritoryOrNot;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Bankers;&lt;br /&gt;
3&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;
== Managing a Transaction Inside a Stored 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;
11&amp;gt; CREATE PROC usp_MyProc&lt;br /&gt;
12&amp;gt; AS&lt;br /&gt;
13&amp;gt; DECLARE&lt;br /&gt;
14&amp;gt;   @TranCount  int&lt;br /&gt;
15&amp;gt; SET&lt;br /&gt;
16&amp;gt;   @TranCount = @@TRANCOUNT&lt;br /&gt;
17&amp;gt; IF @TranCount &amp;gt; 0&lt;br /&gt;
18&amp;gt;   SAVE TRAN usp_MyProc             -- No existing transaction&lt;br /&gt;
19&amp;gt; ELSE&lt;br /&gt;
20&amp;gt;   BEGIN TRAN usp_MyProc            -- Transaction in progress&lt;br /&gt;
21&amp;gt; --do work here ...&lt;br /&gt;
22&amp;gt; IF @@ERROR &amp;gt; 0&lt;br /&gt;
23&amp;gt; BEGIN                              -- Failure&lt;br /&gt;
24&amp;gt;   RAISERROR (&amp;quot;usp_MyProc - Bailing out. &amp;quot;, 16, 1)&lt;br /&gt;
25&amp;gt;   ROLLBACK TRAN usp_MyProc&lt;br /&gt;
26&amp;gt;   RETURN&lt;br /&gt;
27&amp;gt; END&lt;br /&gt;
28&amp;gt; ELSE IF @Trancount = 0             -- Started our own transaction&lt;br /&gt;
29&amp;gt;   COMMIT TRAN usp_MyProc           -- Success&lt;br /&gt;
30&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop procedure usp_MyProc&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== PRINT information 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;
1&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
2&amp;gt;      OrderID int NOT NULL ,&lt;br /&gt;
3&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
4&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
5&amp;gt;      OrderDate datetime NULL ,&lt;br /&gt;
6&amp;gt;      RequiredDate datetime NULL ,&lt;br /&gt;
7&amp;gt;      ShippedDate datetime NULL ,&lt;br /&gt;
8&amp;gt;      ShipVia int NULL ,&lt;br /&gt;
9&amp;gt;      Freight money NULL DEFAULT (0),&lt;br /&gt;
10&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
11&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
12&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
13&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
14&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
15&amp;gt;     ShipCountry nvarchar (15) NULL&lt;br /&gt;
16&amp;gt; )&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; INSERT INTO Orders VALUES (10248,&amp;quot;1&amp;quot;,5,&amp;quot;7/4/1996&amp;quot;,&amp;quot;8/1/2001&amp;quot;,&amp;quot;7/16/2001&amp;quot;,3,32.38,&amp;quot;V&amp;quot;,&amp;quot;A&amp;quot;,&amp;quot;R&amp;quot;,        NULL,N&amp;quot;51100&amp;quot;,&amp;quot;France&amp;quot;)&lt;br /&gt;
9&amp;gt; go&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;    create PROCEDURE spCursorScope&lt;br /&gt;
4&amp;gt;    AS&lt;br /&gt;
5&amp;gt;    DECLARE @Counter      int,&lt;br /&gt;
6&amp;gt;            @OrderID      int,&lt;br /&gt;
7&amp;gt;            @CustomerID   varchar(5)&lt;br /&gt;
8&amp;gt;    DECLARE CursorTest cursor&lt;br /&gt;
9&amp;gt;    LOCAL&lt;br /&gt;
10&amp;gt;    FOR&lt;br /&gt;
11&amp;gt;       SELECT OrderID, CustomerID&lt;br /&gt;
12&amp;gt;       FROM Orders&lt;br /&gt;
13&amp;gt;&lt;br /&gt;
14&amp;gt;    SELECT @Counter = 1&lt;br /&gt;
15&amp;gt;    OPEN CursorTest&lt;br /&gt;
16&amp;gt;    FETCH NEXT FROM CursorTest INTO @OrderID, @CustomerID&lt;br /&gt;
17&amp;gt;    PRINT &amp;quot;Row &amp;quot; + CONVERT(varchar,@Counter) + &amp;quot; has an OrderID of &amp;quot; +&lt;br /&gt;
18&amp;gt;          CONVERT(varchar,@OrderID) + &amp;quot; and a CustomerID of &amp;quot; + @CustomerID&lt;br /&gt;
19&amp;gt;&lt;br /&gt;
20&amp;gt;    WHILE (@Counter&amp;lt;=5) AND (@@FETCH_STATUS=0)&lt;br /&gt;
21&amp;gt;    BEGIN&lt;br /&gt;
22&amp;gt;          SELECT @Counter = @Counter + 1&lt;br /&gt;
23&amp;gt;          FETCH NEXT FROM CursorTest INTO @OrderID, @CustomerID&lt;br /&gt;
24&amp;gt;          PRINT &amp;quot;Row &amp;quot; + CONVERT(varchar,@Counter) + &amp;quot; has an OrderID of &amp;quot; +&lt;br /&gt;
25&amp;gt;          CONVERT(varchar,@OrderID) + &amp;quot; and a CustomerID of &amp;quot; + @CustomerID&lt;br /&gt;
26&amp;gt;    END&lt;br /&gt;
27&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop PROCEDURE spCursorScope;&lt;br /&gt;
3&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop table Orders;&lt;br /&gt;
3&amp;gt;    GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Procedure as a view==&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 TABLE Shippers (&lt;br /&gt;
7&amp;gt;      ShipperID int NOT NULL ,&lt;br /&gt;
8&amp;gt;      CompanyName nvarchar (40) NOT NULL ,&lt;br /&gt;
9&amp;gt;      Phone nvarchar (24) NULL&lt;br /&gt;
10&amp;gt; )&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; INSERT Shippers VALUES(1,&amp;quot;Express&amp;quot;,&amp;quot;(503) 555-9831&amp;quot;)&lt;br /&gt;
4&amp;gt; INSERT Shippers VALUES(2,&amp;quot;Package&amp;quot;,&amp;quot;(503) 555-3199&amp;quot;)&lt;br /&gt;
5&amp;gt; INSERT Shippers VALUES(3,&amp;quot;Shipping&amp;quot;,&amp;quot;(503) 555-9931&amp;quot;)&lt;br /&gt;
6&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&amp;gt;    CREATE PROC spShippers&lt;br /&gt;
2&amp;gt;    AS&lt;br /&gt;
3&amp;gt;       SELECT * FROM Shippers&lt;br /&gt;
4&amp;gt;    GO&lt;br /&gt;
1&amp;gt;    EXEC spShippers&lt;br /&gt;
2&amp;gt;    GO&lt;br /&gt;
ShipperID   CompanyName                              Phone&lt;br /&gt;
----------- ---------------------------------------- ------------------------&lt;br /&gt;
          1 Express                                  (503) 555-9831&lt;br /&gt;
          2 Package                                  (503) 555-3199&lt;br /&gt;
          3 Shipping                                 (503) 555-9931&lt;br /&gt;
(3 rows affected)&lt;br /&gt;
1&amp;gt;    drop PROC spShippers;&lt;br /&gt;
2&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop table Shippers;&lt;br /&gt;
3&amp;gt;    GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Return a 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;&lt;br /&gt;
6&amp;gt; CREATE TABLE Product(&lt;br /&gt;
7&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
8&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
9&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
10&amp;gt;     Color                   nvarchar(15)       NULL,&lt;br /&gt;
11&amp;gt;     StandardCost            money              NOT NULL,&lt;br /&gt;
12&amp;gt;     Size                    nvarchar(5)        NULL,&lt;br /&gt;
13&amp;gt;     Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
14&amp;gt;     ProductLine             nchar(20)           NULL,&lt;br /&gt;
15&amp;gt;     SellStartDate           datetime           NOT NULL,&lt;br /&gt;
16&amp;gt;     SellEndDate             datetime           NULL&lt;br /&gt;
17&amp;gt; )&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into Product values(1,&amp;quot;Product A&amp;quot;, &amp;quot;1&amp;quot;,&amp;quot;Red&amp;quot;,123.123,&amp;quot;1&amp;quot;,1,&amp;quot;ProductLine A&amp;quot;,&amp;quot;1999-03-22&amp;quot;,&amp;quot;2000-03-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(2,&amp;quot;Product B&amp;quot;, &amp;quot;2&amp;quot;,&amp;quot;Yellow&amp;quot;,234.234,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine B&amp;quot;,&amp;quot;2000-03-22&amp;quot;,&amp;quot;2001-03-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(3,&amp;quot;Product C&amp;quot;, &amp;quot;3&amp;quot;,&amp;quot;Pink&amp;quot;,345.345,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine V&amp;quot;,&amp;quot;2001-09-22&amp;quot;,&amp;quot;2006-02-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(4,&amp;quot;Product D&amp;quot;, &amp;quot;4&amp;quot;,&amp;quot;White&amp;quot;,456.456,&amp;quot;1&amp;quot;,4,&amp;quot;ProductLine D&amp;quot;,&amp;quot;2002-08-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(5,&amp;quot;Product E&amp;quot;, &amp;quot;5&amp;quot;,&amp;quot;Black&amp;quot;,567.567,&amp;quot;1&amp;quot;,5,&amp;quot;ProductLine E&amp;quot;,&amp;quot;2003-01-22&amp;quot;,&amp;quot;2003-04-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(6,&amp;quot;Product F&amp;quot;, &amp;quot;6&amp;quot;,&amp;quot;Blue&amp;quot;,678.678,&amp;quot;1&amp;quot;,6,&amp;quot;ProductLine W&amp;quot;,&amp;quot;2004-02-22&amp;quot;,&amp;quot;2005-05-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(7,&amp;quot;Product G&amp;quot;, &amp;quot;7&amp;quot;,&amp;quot;Drak&amp;quot;,789.789,&amp;quot;1&amp;quot;,7,&amp;quot;ProductLine Q&amp;quot;,&amp;quot;2005-03-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(8,&amp;quot;Product H&amp;quot;, &amp;quot;8&amp;quot;,&amp;quot;Gray&amp;quot;,234.123,&amp;quot;1&amp;quot;,8,&amp;quot;ProductLine F&amp;quot;,&amp;quot;2006-04-22&amp;quot;,&amp;quot;2006-09-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(9,&amp;quot;Product I&amp;quot;, &amp;quot;9&amp;quot;,&amp;quot;Red&amp;quot;,543.123,&amp;quot;1&amp;quot;,9,&amp;quot;ProductLine R&amp;quot;,&amp;quot;2007-05-22&amp;quot;,&amp;quot;2008-03-22&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Product values(0,&amp;quot;Product J&amp;quot;, &amp;quot;0&amp;quot;,&amp;quot;Gold&amp;quot;,765.123,&amp;quot;1&amp;quot;,0,&amp;quot;ProductLine J&amp;quot;,&amp;quot;2008-06-22&amp;quot;,&amp;quot;2009-03-22&amp;quot;);&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;&lt;br /&gt;
3&amp;gt; CREATE PROCEDURE spProductCountBySubCategory&lt;br /&gt;
4&amp;gt;   @SubID Int&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt;   DECLARE @Out Int&lt;br /&gt;
7&amp;gt;   SELECT @Out = Count(*)&lt;br /&gt;
8&amp;gt;   FROM Product&lt;br /&gt;
9&amp;gt;   WHERE ProductID = @SubID&lt;br /&gt;
10&amp;gt; RETURN @Out&lt;br /&gt;
11&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;&lt;br /&gt;
5&amp;gt; drop PROCEDURE spProductCountBySubCategory;&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Product;&lt;br /&gt;
4&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;
== Returning Values from a View as Stored Procedure Output Parameters==&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;
4&amp;gt; create table Billings (&lt;br /&gt;
5&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
6&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
7&amp;gt;     BillingDate        datetime,&lt;br /&gt;
8&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
9&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
10&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
11&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
12&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
13&amp;gt;&lt;br /&gt;
14&amp;gt; );&lt;br /&gt;
15&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; INSERT INTO Billings VALUES (1, 1, &amp;quot;2005-01-22&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (2, 2, &amp;quot;2001-02-21&amp;quot;, 165, 1,&amp;quot;2002-02-22&amp;quot;,123,321.);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (3, 3, &amp;quot;2003-05-02&amp;quot;, 165, 1,&amp;quot;2005-04-12&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (4, 4, &amp;quot;1999-03-12&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (5, 5, &amp;quot;2000-04-23&amp;quot;, 165, 1,&amp;quot;2005-04-17&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (6, 6, &amp;quot;2001-06-14&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (7, 7, &amp;quot;2002-07-15&amp;quot;, 165, 1,&amp;quot;2005-04-19&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (8, 8, &amp;quot;2003-08-16&amp;quot;, 165, 1,&amp;quot;2005-04-20&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (9, 9, &amp;quot;2004-09-17&amp;quot;, 165, 1,&amp;quot;2005-04-21&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (0, 0, &amp;quot;2005-10-18&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&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;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE PROCEDURE usp_MinMaxSubTotal&lt;br /&gt;
5&amp;gt; @minSubTotal money OUTPUT,&lt;br /&gt;
6&amp;gt; @maxSubTotal money OUTPUT&lt;br /&gt;
7&amp;gt; AS&lt;br /&gt;
8&amp;gt; SET @minSubTotal =&lt;br /&gt;
9&amp;gt;     (SELECT TOP 1 BillingTotal&lt;br /&gt;
10&amp;gt;         FROM Billings ORDER BY BillingTotal)&lt;br /&gt;
11&amp;gt; SET @maxSubTotal =&lt;br /&gt;
12&amp;gt;     (SELECT TOP 1 BillingTotal&lt;br /&gt;
13&amp;gt;         FROM Billings ORDER BY BillingTotal DESC)&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; DECLARE @lclmin money, @lclmax money&lt;br /&gt;
3&amp;gt; EXEC usp_MinMaxSubTotal @minSubTotal = @lclmin OUTPUT,&lt;br /&gt;
4&amp;gt;     @maxSubTotal = @lclmax OUTPUT&lt;br /&gt;
5&amp;gt; SELECT @lclmin &amp;quot;Min. SubTotal&amp;quot;, @lclmax &amp;quot;Max. SubTotal&amp;quot;&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
Min. SubTotal         Max. SubTotal&lt;br /&gt;
--------------------- ---------------------&lt;br /&gt;
             165.0000              165.0000&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROCEDURE usp_MinMaxSubTotal ;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Billings;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Stored Procedures as Parameterized Views==&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;&lt;br /&gt;
6&amp;gt; CREATE TABLE Product(&lt;br /&gt;
7&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
8&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
9&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
10&amp;gt;      Color                   nvarchar(15)       NULL,&lt;br /&gt;
11&amp;gt;      StandardCost            money              NOT NULL,&lt;br /&gt;
12&amp;gt;      Size                    nvarchar(5)        NULL,&lt;br /&gt;
13&amp;gt;      Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
14&amp;gt;      ProductLine             nchar(20)           NULL,&lt;br /&gt;
15&amp;gt;      SellStartDate           datetime           NOT NULL,&lt;br /&gt;
16&amp;gt;      SellEndDate             datetime           NULL&lt;br /&gt;
17&amp;gt;  )&lt;br /&gt;
18&amp;gt;  GO&lt;br /&gt;
1&amp;gt; insert into Product values(1,&amp;quot;Product A&amp;quot;, &amp;quot;1&amp;quot;,&amp;quot;Red&amp;quot;,123.123,&amp;quot;1&amp;quot;,1,&amp;quot;ProductLine A&amp;quot;,&amp;quot;1999-03-22&amp;quot;,&amp;quot;2000-03-22&amp;quot;);&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;&lt;br /&gt;
3&amp;gt; insert into Product values(2,&amp;quot;Product B&amp;quot;, &amp;quot;2&amp;quot;,&amp;quot;Yellow&amp;quot;,234.234,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine B&amp;quot;,&amp;quot;2000-03-22&amp;quot;,&amp;quot;2001-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(3,&amp;quot;Product C&amp;quot;, &amp;quot;3&amp;quot;,&amp;quot;Pink&amp;quot;,345.345,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine V&amp;quot;,&amp;quot;2001-09-22&amp;quot;,&amp;quot;2006-02-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(4,&amp;quot;Product D&amp;quot;, &amp;quot;4&amp;quot;,&amp;quot;White&amp;quot;,456.456,&amp;quot;1&amp;quot;,4,&amp;quot;ProductLine D&amp;quot;,&amp;quot;2002-08-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(5,&amp;quot;Product E&amp;quot;, &amp;quot;5&amp;quot;,&amp;quot;Black&amp;quot;,567.567,&amp;quot;1&amp;quot;,5,&amp;quot;ProductLine E&amp;quot;,&amp;quot;2003-01-22&amp;quot;,&amp;quot;2003-04-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(6,&amp;quot;Product F&amp;quot;, &amp;quot;6&amp;quot;,&amp;quot;Blue&amp;quot;,678.678,&amp;quot;1&amp;quot;,6,&amp;quot;ProductLine W&amp;quot;,&amp;quot;2004-02-22&amp;quot;,&amp;quot;2005-05-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(7,&amp;quot;Product G&amp;quot;, &amp;quot;7&amp;quot;,&amp;quot;Drak&amp;quot;,789.789,&amp;quot;1&amp;quot;,7,&amp;quot;ProductLine Q&amp;quot;,&amp;quot;2005-03-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(8,&amp;quot;Product H&amp;quot;, &amp;quot;8&amp;quot;,&amp;quot;Gray&amp;quot;,234.123,&amp;quot;1&amp;quot;,8,&amp;quot;ProductLine F&amp;quot;,&amp;quot;2006-04-22&amp;quot;,&amp;quot;2006-09-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(9,&amp;quot;Product I&amp;quot;, &amp;quot;9&amp;quot;,&amp;quot;Red&amp;quot;,543.123,&amp;quot;1&amp;quot;,9,&amp;quot;ProductLine R&amp;quot;,&amp;quot;2007-05-22&amp;quot;,&amp;quot;2008-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into Product values(0,&amp;quot;Product J&amp;quot;, &amp;quot;0&amp;quot;,&amp;quot;Gold&amp;quot;,765.123,&amp;quot;1&amp;quot;,0,&amp;quot;ProductLine J&amp;quot;,&amp;quot;2008-06-22&amp;quot;,&amp;quot;2009-03-22&amp;quot;);&lt;br /&gt;
4&amp;gt; GO&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;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE VIEW vProductCosts&lt;br /&gt;
7&amp;gt; AS&lt;br /&gt;
8&amp;gt; SELECT ProductID, Name, ProductNumber, StandardCost&lt;br /&gt;
9&amp;gt; FROM Product&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE PROCEDURE spProductCosts&lt;br /&gt;
3&amp;gt; AS&lt;br /&gt;
4&amp;gt; SELECT ProductID, Name, ProductNumber, StandardCost&lt;br /&gt;
5&amp;gt; FROM Product&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; EXECUTE spProductCosts&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ProductID   Name                      ProductNumber             StandardCost&lt;br /&gt;
----------- ------------------------- ------------------------- ---------------------&lt;br /&gt;
          1 Product A                 1                                      123.1230&lt;br /&gt;
          2 Product B                 2                                      234.2340&lt;br /&gt;
          3 Product C                 3                                      345.3450&lt;br /&gt;
          4 Product D                 4                                      456.4560&lt;br /&gt;
          5 Product E                 5                                      567.5670&lt;br /&gt;
          6 Product F                 6                                      678.6780&lt;br /&gt;
          7 Product G                 7                                      789.7890&lt;br /&gt;
          8 Product H                 8                                      234.1230&lt;br /&gt;
          9 Product I                 9                                      543.1230&lt;br /&gt;
          0 Product J                 0                                      765.1230&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROCEDURE spProductCosts;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop VIEW vProductCosts;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Product;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>