<?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%2FCursor%2FOpen_cursor</id>
		<title>SQL Server/T-SQL/Cursor/Open cursor - История изменений</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%2FCursor%2FOpen_cursor"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL/Cursor/Open_cursor&amp;action=history"/>
		<updated>2026-04-06T20:38:03Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

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

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL/Cursor/Open_cursor&amp;diff=5533&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/Cursor/Open_cursor&amp;diff=5533&amp;oldid=prev"/>
				<updated>2010-05-26T10:19:47Z</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 SQL script that declares and uses a cursor==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
18&amp;gt; create table Bankers(&lt;br /&gt;
19&amp;gt;    BankerID             Integer,&lt;br /&gt;
20&amp;gt;    BankerName           VARCHAR(20),&lt;br /&gt;
21&amp;gt;    BankerContactLName   VARCHAR(20),&lt;br /&gt;
22&amp;gt;    BankerContactFName   VARCHAR(20),&lt;br /&gt;
23&amp;gt;    BankerCity           VARCHAR(20),&lt;br /&gt;
24&amp;gt;    BankerState          VARCHAR(20),&lt;br /&gt;
25&amp;gt;    BankerZipCode        VARCHAR(20),&lt;br /&gt;
26&amp;gt;    BankerPhone          VARCHAR(20)&lt;br /&gt;
27&amp;gt; )&lt;br /&gt;
28&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; DECLARE Bankers_Cursor CURSOR&lt;br /&gt;
3&amp;gt; STATIC&lt;br /&gt;
4&amp;gt; FOR&lt;br /&gt;
5&amp;gt;     SELECT BankerID, BankerName&lt;br /&gt;
6&amp;gt;     FROM Bankers&lt;br /&gt;
7&amp;gt;     ORDER BY BankerName&lt;br /&gt;
8&amp;gt; OPEN Bankers_Cursor&lt;br /&gt;
9&amp;gt; FETCH NEXT FROM Bankers_Cursor&lt;br /&gt;
10&amp;gt; WHILE @@FETCH_STATUS = 0&lt;br /&gt;
11&amp;gt;     FETCH NEXT FROM Bankers_Cursor&lt;br /&gt;
12&amp;gt; CLOSE Bankers_Cursor&lt;br /&gt;
13&amp;gt; DEALLOCATE Bankers_Cursor&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          1 ABC Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          2 DEF Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          9 DFG Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          0 GHJ Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          3 HJI Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          7 OIP Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          4 QWE Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          5 RTY Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          8 SAD Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
          6 YUI Inc.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
BankerID    BankerName&lt;br /&gt;
----------- --------------------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Bankers;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==OPEN a cursor==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
6&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
7&amp;gt;      OrderID int NOT NULL ,&lt;br /&gt;
8&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
9&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
10&amp;gt;     OrderDate datetime NULL ,&lt;br /&gt;
11&amp;gt;     RequiredDate datetime NULL ,&lt;br /&gt;
12&amp;gt;     ShippedDate datetime NULL ,&lt;br /&gt;
13&amp;gt;     ShipVia int NULL ,&lt;br /&gt;
14&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
15&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
16&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
17&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
18&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
19&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
20&amp;gt;     ShipCountry nvarchar (15) NULL&lt;br /&gt;
21&amp;gt; )&lt;br /&gt;
22&amp;gt; GO&lt;br /&gt;
1&amp;gt;    CREATE PROCEDURE spCursorScope&lt;br /&gt;
2&amp;gt;    AS&lt;br /&gt;
3&amp;gt;    DECLARE @Counter      int,&lt;br /&gt;
4&amp;gt;            @OrderID      int,&lt;br /&gt;
5&amp;gt;            @CustomerID   varchar(5)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt;    DECLARE CursorTest CURSOR&lt;br /&gt;
8&amp;gt;    GLOBAL&lt;br /&gt;
9&amp;gt;    FOR&lt;br /&gt;
10&amp;gt;       SELECT OrderID, CustomerID&lt;br /&gt;
11&amp;gt;       FROM Orders&lt;br /&gt;
12&amp;gt;&lt;br /&gt;
13&amp;gt;    SELECT @Counter = 1&lt;br /&gt;
14&amp;gt;    OPEN CursorTest&lt;br /&gt;
15&amp;gt;    FETCH NEXT FROM CursorTest INTO @OrderID, @CustomerID&lt;br /&gt;
16&amp;gt;    PRINT &amp;quot;Row &amp;quot; + CONVERT(varchar,@Counter) + &amp;quot; has an OrderID of &amp;quot; +&lt;br /&gt;
17&amp;gt;       CONVERT(varchar,@OrderID) + &amp;quot; and a CustomerID of &amp;quot; + @CustomerID&lt;br /&gt;
18&amp;gt;    WHILE (@Counter&amp;lt;=5) AND (@@FETCH_STATUS=0)&lt;br /&gt;
19&amp;gt;    BEGIN&lt;br /&gt;
20&amp;gt;       SELECT @Counter = @Counter + 1&lt;br /&gt;
21&amp;gt;       FETCH NEXT FROM CursorTest INTO @OrderID, @CustomerID&lt;br /&gt;
22&amp;gt;       PRINT &amp;quot;Row &amp;quot; + CONVERT(varchar,@Counter) + &amp;quot; has an OrderID of &amp;quot; +&lt;br /&gt;
23&amp;gt;       CONVERT(varchar,@OrderID) + &amp;quot; and a CustomerID of &amp;quot; + @CustomerID&lt;br /&gt;
24&amp;gt;    END&lt;br /&gt;
25&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&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>