<?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_Tutorial%2FTransact_SQL%2Fwhile</id>
		<title>SQL Server/T-SQL Tutorial/Transact SQL/while - История изменений</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_Tutorial%2FTransact_SQL%2Fwhile"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/while&amp;action=history"/>
		<updated>2026-04-04T03:58:49Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/while&amp;diff=6372&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_Tutorial/Transact_SQL/while&amp;diff=6372&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://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/while&amp;diff=6373&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_Tutorial/Transact_SQL/while&amp;diff=6373&amp;oldid=prev"/>
				<updated>2010-05-26T10:22:48Z</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;== A script that tests and adjusts credit amounts with a WHILE loop==&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;
16&amp;gt;&lt;br /&gt;
17&amp;gt;&lt;br /&gt;
18&amp;gt; create table Billings (&lt;br /&gt;
19&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
20&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
21&amp;gt;     BillingDate        datetime,&lt;br /&gt;
22&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
23&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
24&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
25&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
26&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
27&amp;gt;&lt;br /&gt;
28&amp;gt; );&lt;br /&gt;
29&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; WHILE (SELECT SUM(BillingTotal - CreditTotal - PaymentTotal) FROM Billings) &amp;gt;= 50000&lt;br /&gt;
4&amp;gt;     BEGIN&lt;br /&gt;
5&amp;gt;         UPDATE Billings&lt;br /&gt;
6&amp;gt;         SET CreditTotal = CreditTotal + .01&lt;br /&gt;
7&amp;gt;         WHERE BillingTotal  - CreditTotal - PaymentTotal &amp;gt; 0&lt;br /&gt;
8&amp;gt;         IF (SELECT MAX(CreditTotal) FROM Billings) &amp;gt; 3000&lt;br /&gt;
9&amp;gt;             BREAK&lt;br /&gt;
10&amp;gt;         ELSE --(SELECT MAX(CreditTotal) FROM Billings) &amp;lt;= 3000&lt;br /&gt;
11&amp;gt;             CONTINUE&lt;br /&gt;
12&amp;gt;     END&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt; SELECT BillingDate, BillingTotal, CreditTotal&lt;br /&gt;
2&amp;gt; FROM Billings&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
BillingDate             BillingTotal CreditTotal&lt;br /&gt;
----------------------- ------------ -----------&lt;br /&gt;
2005-01-22 00:00:00.000          165         321&lt;br /&gt;
2001-02-21 00:00:00.000          165         321&lt;br /&gt;
2003-05-02 00:00:00.000          165         321&lt;br /&gt;
1999-03-12 00:00:00.000          165         321&lt;br /&gt;
2000-04-23 00:00:00.000          165         321&lt;br /&gt;
2001-06-14 00:00:00.000          165         321&lt;br /&gt;
2002-07-15 00:00:00.000          165         321&lt;br /&gt;
2003-08-16 00:00:00.000          165         321&lt;br /&gt;
2004-09-17 00:00:00.000          165         321&lt;br /&gt;
2005-10-18 00:00:00.000          165         321&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Billings;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== How to perform repetitive processing==&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;
The syntax of the WHILE statement&lt;br /&gt;
WHILE expression&lt;br /&gt;
    {statement|BEGIN...END}&lt;br /&gt;
    [BREAK]&lt;br /&gt;
    [CONTINUE]&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Insert 100 rows of data: RAND==&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;
5&amp;gt; CREATE TABLE random_data&lt;br /&gt;
6&amp;gt; (&lt;br /&gt;
7&amp;gt; col1        int PRIMARY KEY,&lt;br /&gt;
8&amp;gt; col2        int,&lt;br /&gt;
9&amp;gt; col3        char(15)&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; DECLARE @counter int, @col2 int, @col3 char(15)&lt;br /&gt;
3&amp;gt; &lt;br /&gt;
4&amp;gt; &lt;br /&gt;
5&amp;gt; SELECT @counter=0, @col2=RAND(@@spid + cpu + physical_io)&lt;br /&gt;
6&amp;gt; FROM master..sysprocesses where spid=@@spid&lt;br /&gt;
7&amp;gt;&lt;br /&gt;
8&amp;gt; WHILE (@counter &amp;lt; 1000)&lt;br /&gt;
9&amp;gt;     BEGIN&lt;br /&gt;
10&amp;gt;     SELECT @counter=@counter + 10,   &lt;br /&gt;
11&amp;gt;     @col2=&lt;br /&gt;
12&amp;gt;         CASE        &lt;br /&gt;
13&amp;gt;             WHEN CONVERT(int, RAND() * 1000) % 2 = 1&lt;br /&gt;
14&amp;gt;             THEN (CONVERT(int, RAND() * 100000) % 10000 * -1)&lt;br /&gt;
15&amp;gt;             ELSE CONVERT(int, RAND() * 100000) % 10000&lt;br /&gt;
16&amp;gt;         END,&lt;br /&gt;
17&amp;gt;     @col3=       &lt;br /&gt;
18&amp;gt;         CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65) -- 65 is &amp;quot;A&amp;quot;&lt;br /&gt;
19&amp;gt;             + CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
20&amp;gt;             + CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
21&amp;gt;             + CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
22&amp;gt;             + REPLICATE(CHAR((CONVERT(int, RAND() * 1000) % 26 )&lt;br /&gt;
23&amp;gt;             + 65), 11)&lt;br /&gt;
24&amp;gt;&lt;br /&gt;
25&amp;gt;     INSERT random_data VALUES (@counter, @col2, @col3)&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 table random_data;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== This procedure inserts rows by using while loop==&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 works_on (emp_no INTEGER NOT NULL,&lt;br /&gt;
7&amp;gt;                   project_no CHAR(4) NOT NULL,&lt;br /&gt;
8&amp;gt;                   job CHAR (15) NULL,&lt;br /&gt;
9&amp;gt;                   enter_date DATETIME NULL)&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;       declare @i integer, @j integer&lt;br /&gt;
4&amp;gt;       declare @job char(20), @enter_date datetime&lt;br /&gt;
5&amp;gt;       declare @project_no char(4)&lt;br /&gt;
6&amp;gt;       declare @dept_no char(4)&lt;br /&gt;
7&amp;gt;       set @i = 1&lt;br /&gt;
8&amp;gt;       set @j = 1&lt;br /&gt;
9&amp;gt;       set @job = &amp;quot;Analyst&amp;quot;&lt;br /&gt;
10&amp;gt;       set @enter_date = GETDATE()&lt;br /&gt;
11&amp;gt;       set @dept_no = &amp;quot;d1&amp;quot;&lt;br /&gt;
12&amp;gt;       while @i &amp;lt; 3001&lt;br /&gt;
13&amp;gt;       begin&lt;br /&gt;
14&amp;gt;         while @j &amp;lt; 5&lt;br /&gt;
15&amp;gt;          begin&lt;br /&gt;
16&amp;gt;           if (@j = 1) set @dept_no = &amp;quot;d1&amp;quot;&lt;br /&gt;
17&amp;gt;           else if (@j = 2) set @dept_no = &amp;quot;d2&amp;quot;&lt;br /&gt;
18&amp;gt;            else if (@j = 3) set @dept_no = &amp;quot;d3&amp;quot;&lt;br /&gt;
19&amp;gt;            else set @dept_no = &amp;quot;d4&amp;quot;&lt;br /&gt;
20&amp;gt;        insert into works_on&lt;br /&gt;
21&amp;gt;            values (@i, @dept_no, @job, @enter_date)&lt;br /&gt;
22&amp;gt;        set @j = @j+1&lt;br /&gt;
23&amp;gt;         end&lt;br /&gt;
24&amp;gt;       set @i = @i+1&lt;br /&gt;
25&amp;gt;       set @j = 1&lt;br /&gt;
26&amp;gt;       end&lt;br /&gt;
27&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)&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Use while loop to insert data==&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; DECLARE @T TABLE&lt;br /&gt;
7&amp;gt; (&lt;br /&gt;
8&amp;gt;   col1 INT NOT NULL PRIMARY KEY,&lt;br /&gt;
9&amp;gt;   col2 INT NOT NULL,&lt;br /&gt;
10&amp;gt;   filler CHAR(200) NOT NULL DEFAULT(&amp;quot;a&amp;quot;),&lt;br /&gt;
11&amp;gt;   UNIQUE(col2, col1)&lt;br /&gt;
12&amp;gt; );&lt;br /&gt;
13&amp;gt; INSERT INTO @T(col1, col2)&lt;br /&gt;
14&amp;gt;   SELECT n, (n - 1) % 100 + 1 FROM dbo.Nums&lt;br /&gt;
15&amp;gt;   WHERE n &amp;lt;= 100;&lt;br /&gt;
16&amp;gt;&lt;br /&gt;
17&amp;gt; SELECT * FROM @T WHERE col1 = 1;&lt;br /&gt;
18&amp;gt;&lt;br /&gt;
19&amp;gt; SELECT * FROM @T WHERE col1 &amp;lt;= 50;&lt;br /&gt;
20&amp;gt;&lt;br /&gt;
21&amp;gt; SELECT * FROM @T WHERE col2 = 1;&lt;br /&gt;
22&amp;gt;&lt;br /&gt;
23&amp;gt; SELECT * FROM @T WHERE col2 &amp;lt;= 2;&lt;br /&gt;
24&amp;gt;&lt;br /&gt;
25&amp;gt; SELECT * FROM @T WHERE col2 &amp;lt;= 50;&lt;br /&gt;
26&amp;gt; GO&lt;br /&gt;
(100 rows affected)&lt;br /&gt;
col1        col2        filler&lt;br /&gt;
----------- ----------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------&lt;br /&gt;
------------------------&lt;br /&gt;
          1           1 a&lt;br /&gt;
&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
col1        col2        filler&lt;br /&gt;
----------- ----------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------&lt;br /&gt;
------------------------&lt;br /&gt;
          1           1 a&lt;br /&gt;
          2           2 a&lt;br /&gt;
          3           3 a&lt;br /&gt;
          4           4 a&lt;br /&gt;
          5           5 a&lt;br /&gt;
          6           6 a&lt;br /&gt;
          7           7 a&lt;br /&gt;
          8           8 a&lt;br /&gt;
          9           9 a&lt;br /&gt;
         10          10 a&lt;br /&gt;
         11          11 a&lt;br /&gt;
         12          12 a&lt;br /&gt;
         13          13 a&lt;br /&gt;
         14          14 a&lt;br /&gt;
         15          15 a&lt;br /&gt;
         16          16 a&lt;br /&gt;
         17          17 a&lt;br /&gt;
         18          18 a&lt;br /&gt;
         19          19 a&lt;br /&gt;
         20          20 a&lt;br /&gt;
         21          21 a&lt;br /&gt;
         22          22 a&lt;br /&gt;
         23          23 a&lt;br /&gt;
         24          24 a&lt;br /&gt;
         25          25 a&lt;br /&gt;
         26          26 a&lt;br /&gt;
         27          27 a&lt;br /&gt;
         28          28 a&lt;br /&gt;
         29          29 a&lt;br /&gt;
         30          30 a&lt;br /&gt;
         31          31 a&lt;br /&gt;
         32          32 a&lt;br /&gt;
         33          33 a&lt;br /&gt;
         34          34 a&lt;br /&gt;
         35          35 a&lt;br /&gt;
         36          36 a&lt;br /&gt;
         37          37 a&lt;br /&gt;
         38          38 a&lt;br /&gt;
         39          39 a&lt;br /&gt;
         40          40 a&lt;br /&gt;
         41          41 a&lt;br /&gt;
         42          42 a&lt;br /&gt;
         43          43 a&lt;br /&gt;
         44          44 a&lt;br /&gt;
         45          45 a&lt;br /&gt;
         46          46 a&lt;br /&gt;
         47          47 a&lt;br /&gt;
         48          48 a&lt;br /&gt;
         49          49 a&lt;br /&gt;
         50          50 a&lt;br /&gt;
&lt;br /&gt;
(50 rows affected)&lt;br /&gt;
col1        col2        filler&lt;br /&gt;
----------- ----------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------&lt;br /&gt;
------------------------&lt;br /&gt;
          1           1 a&lt;br /&gt;
&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
col1        col2        filler&lt;br /&gt;
----------- ----------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------&lt;br /&gt;
------------------------&lt;br /&gt;
          1           1 a&lt;br /&gt;
          2           2 a&lt;br /&gt;
&lt;br /&gt;
(2 rows affected)&lt;br /&gt;
col1        col2        filler&lt;br /&gt;
----------- ----------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------&lt;br /&gt;
------------------------&lt;br /&gt;
          1           1 a&lt;br /&gt;
          2           2 a&lt;br /&gt;
          3           3 a&lt;br /&gt;
          4           4 a&lt;br /&gt;
          5           5 a&lt;br /&gt;
          6           6 a&lt;br /&gt;
          7           7 a&lt;br /&gt;
          8           8 a&lt;br /&gt;
          9           9 a&lt;br /&gt;
         10          10 a&lt;br /&gt;
         11          11 a&lt;br /&gt;
         12          12 a&lt;br /&gt;
         13          13 a&lt;br /&gt;
         14          14 a&lt;br /&gt;
         15          15 a&lt;br /&gt;
         16          16 a&lt;br /&gt;
         17          17 a&lt;br /&gt;
         18          18 a&lt;br /&gt;
         19          19 a&lt;br /&gt;
         20          20 a&lt;br /&gt;
         21          21 a&lt;br /&gt;
         22          22 a&lt;br /&gt;
         23          23 a&lt;br /&gt;
         24          24 a&lt;br /&gt;
         25          25 a&lt;br /&gt;
         26          26 a&lt;br /&gt;
         27          27 a&lt;br /&gt;
         28          28 a&lt;br /&gt;
         29          29 a&lt;br /&gt;
         30          30 a&lt;br /&gt;
         31          31 a&lt;br /&gt;
         32          32 a&lt;br /&gt;
         33          33 a&lt;br /&gt;
         34          34 a&lt;br /&gt;
         35          35 a&lt;br /&gt;
         36          36 a&lt;br /&gt;
         37          37 a&lt;br /&gt;
         38          38 a&lt;br /&gt;
         39          39 a&lt;br /&gt;
         40          40 a&lt;br /&gt;
         41          41 a&lt;br /&gt;
         42          42 a&lt;br /&gt;
         43          43 a&lt;br /&gt;
         44          44 a&lt;br /&gt;
         45          45 a&lt;br /&gt;
         46          46 a&lt;br /&gt;
         47          47 a&lt;br /&gt;
         48          48 a&lt;br /&gt;
         49          49 a&lt;br /&gt;
         50          50 a&lt;br /&gt;
&lt;br /&gt;
(50 rows affected)&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using a Subquery with a Single-Statement WHILE Loop==&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;
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; WHILE (SELECT AVG (Salary) FROM Employee) &amp;lt; $10000&lt;br /&gt;
4&amp;gt;   UPDATE Employee&lt;br /&gt;
5&amp;gt;   SET&lt;br /&gt;
6&amp;gt;     Salary = Salary * 1.05&lt;br /&gt;
7&amp;gt;&lt;br /&gt;
8&amp;gt;&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt;&lt;br /&gt;
11&amp;gt; drop table employee;&lt;br /&gt;
12&amp;gt; GO&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
(9 rows affected)&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== WHILE @@FETCH_STATUS = 0==&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;&lt;br /&gt;
6&amp;gt;     DROP PROCEDURE pr_updateindex&lt;br /&gt;
7&amp;gt;     GO&lt;br /&gt;
1&amp;gt;     CREATE PROCEDURE pr_updateindex&lt;br /&gt;
2&amp;gt;     AS&lt;br /&gt;
3&amp;gt;     SET NOCOUNT ON&lt;br /&gt;
4&amp;gt;     DECLARE getindex_curs CURSOR&lt;br /&gt;
5&amp;gt;          FOR&lt;br /&gt;
6&amp;gt;               SELECT name FROM sysobjects WHERE type = &amp;quot;U&amp;quot;&lt;br /&gt;
7&amp;gt;     DECLARE @holdtable varchar(30)&lt;br /&gt;
8&amp;gt;     DECLARE @message varchar(40)&lt;br /&gt;
9&amp;gt;     DECLARE @dynamic varchar(51)&lt;br /&gt;
10&amp;gt;     OPEN getindex_curs&lt;br /&gt;
11&amp;gt;     FETCH NEXT FROM getindex_curs into @holdtable&lt;br /&gt;
12&amp;gt;     WHILE @@FETCH_STATUS = 0 BEGIN&lt;br /&gt;
13&amp;gt;            SELECT @dynamic = &amp;quot;UPDATE STATISTICS &amp;quot; + @holdtable&lt;br /&gt;
14&amp;gt;            SELECT @message = &amp;quot;Updating &amp;quot; + @holdtable&lt;br /&gt;
15&amp;gt;            EXEC (@dynamic )&lt;br /&gt;
16&amp;gt;     PRINT @message&lt;br /&gt;
17&amp;gt;          FETCH NEXT FROM getindex_curs into @holdtable&lt;br /&gt;
18&amp;gt;     END&lt;br /&gt;
19&amp;gt;     CLOSE getindex_curs&lt;br /&gt;
20&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     EXEC pr_updateindex&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== While loop controlled by an aggregate 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;
3&amp;gt; CREATE TABLE Product(&lt;br /&gt;
4&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
5&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
6&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
7&amp;gt;     Color                   nvarchar(15)       NULL,&lt;br /&gt;
8&amp;gt;      StandardCost            money              NOT NULL,&lt;br /&gt;
9&amp;gt;      Size                    nvarchar(5)        NULL,&lt;br /&gt;
10&amp;gt;      Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
11&amp;gt;      ProductLine             nchar(20)           NULL,&lt;br /&gt;
12&amp;gt;      SellStartDate           datetime           NOT NULL,&lt;br /&gt;
13&amp;gt;      SellEndDate             datetime           NULL&lt;br /&gt;
14&amp;gt;  )&lt;br /&gt;
15&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; WHILE (SELECT AVG(StandardCost) FROM Product) &amp;lt; $1200&lt;br /&gt;
6&amp;gt; BEGIN&lt;br /&gt;
7&amp;gt;   UPDATE Product SET StandardCost = StandardCost * 1.25&lt;br /&gt;
8&amp;gt;   SELECT MAX(StandardCost) FROM Product&lt;br /&gt;
9&amp;gt;   IF (SELECT MAX(StandardCost) FROM Product) &amp;gt; $4000&lt;br /&gt;
10&amp;gt;     &lt;br /&gt;
11&amp;gt;     BREAK&lt;br /&gt;
12&amp;gt;    ELSE&lt;br /&gt;
13&amp;gt;      &lt;br /&gt;
14&amp;gt;      CONTINUE&lt;br /&gt;
15&amp;gt;  END&lt;br /&gt;
16&amp;gt;  PRINT &amp;quot;Done.&amp;quot;&lt;br /&gt;
17&amp;gt;  GO&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
---------------------&lt;br /&gt;
             987.2363&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
---------------------&lt;br /&gt;
            1234.0454&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
---------------------&lt;br /&gt;
            1542.5568&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
---------------------&lt;br /&gt;
            1928.1960&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
---------------------&lt;br /&gt;
            2410.2450&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
Done.&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;&lt;br /&gt;
2&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== WHILE with AND operator==&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;
== While with counter==&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;
8&amp;gt; CREATE TABLE Product(&lt;br /&gt;
9&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
10&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
11&amp;gt;      ProductNumber           nvarchar(25)               ,&lt;br /&gt;
12&amp;gt;      Color                   nvarchar(15)       NULL,&lt;br /&gt;
13&amp;gt;      StandardCost            money              NOT NULL,&lt;br /&gt;
14&amp;gt;      Size                    nvarchar(5)        NULL,&lt;br /&gt;
15&amp;gt;      Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
16&amp;gt;      ProductLine             nchar(20)           NULL,&lt;br /&gt;
17&amp;gt;      SellStartDate           datetime           NOT NULL,&lt;br /&gt;
18&amp;gt;      SellEndDate             datetime           NULL&lt;br /&gt;
19&amp;gt;  )&lt;br /&gt;
20&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;&lt;br /&gt;
7&amp;gt; DECLARE @Counter Int&lt;br /&gt;
8&amp;gt; SET @Counter = 1&lt;br /&gt;
9&amp;gt; WHILE @Counter &amp;lt; 4&lt;br /&gt;
10&amp;gt;  BEGIN&lt;br /&gt;
11&amp;gt;   PRINT &amp;quot;SubCategory &amp;quot;&lt;br /&gt;
12&amp;gt;   SELECT Name, ProductID&lt;br /&gt;
13&amp;gt;   FROM Product&lt;br /&gt;
14&amp;gt;   WHERE ProductID = @Counter&lt;br /&gt;
15&amp;gt;    SET @Counter = @Counter + 1&lt;br /&gt;
16&amp;gt;  END&lt;br /&gt;
17&amp;gt;  GO&lt;br /&gt;
SubCategory&lt;br /&gt;
Name                      ProductID&lt;br /&gt;
------------------------- -----------&lt;br /&gt;
Product A                           1&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
SubCategory&lt;br /&gt;
Name                      ProductID&lt;br /&gt;
------------------------- -----------&lt;br /&gt;
Product B                           2&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
SubCategory&lt;br /&gt;
Name                      ProductID&lt;br /&gt;
------------------------- -----------&lt;br /&gt;
Product C                           3&lt;br /&gt;
(1 rows affected)&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&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>