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

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Cursor/Fetch_cursor&amp;diff=6298&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/Cursor/Fetch_cursor&amp;diff=6298&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/Cursor/Fetch_cursor&amp;diff=6299&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/Cursor/Fetch_cursor&amp;diff=6299&amp;oldid=prev"/>
				<updated>2010-05-26T10:22:32Z</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;== Fetch cursor value with 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; CREATE TABLE Orders (&lt;br /&gt;
6&amp;gt;      OrderID int NOT NULL ,&lt;br /&gt;
7&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
8&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
9&amp;gt;      OrderDate datetime NULL ,&lt;br /&gt;
10&amp;gt;     RequiredDate datetime NULL ,&lt;br /&gt;
11&amp;gt;     ShippedDate datetime NULL ,&lt;br /&gt;
12&amp;gt;     ShipVia int NULL ,&lt;br /&gt;
13&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
14&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
15&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
16&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
17&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
18&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
19&amp;gt;     ShipCountry nvarchar (15) NULL&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;&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;
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;    CREATE PROCEDURE spCursorScroll&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;    SCROLL&lt;br /&gt;
11&amp;gt;    FOR&lt;br /&gt;
12&amp;gt;       SELECT OrderID, CustomerID&lt;br /&gt;
13&amp;gt;       FROM Orders&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;    WHILE (@Counter&amp;lt;=5) AND (@@FETCH_STATUS=0)&lt;br /&gt;
20&amp;gt;    BEGIN&lt;br /&gt;
21&amp;gt;          SELECT @Counter = @Counter + 1&lt;br /&gt;
22&amp;gt;          FETCH NEXT FROM CursorTest INTO @OrderID, @CustomerID&lt;br /&gt;
23&amp;gt;          PRINT &amp;quot;Row &amp;quot; + CONVERT(varchar,@Counter) + &amp;quot; has an OrderID of &amp;quot; +&lt;br /&gt;
24&amp;gt;          CONVERT(varchar,@OrderID) + &amp;quot; and a CustomerID of &amp;quot; + @CustomerID&lt;br /&gt;
25&amp;gt;    END&lt;br /&gt;
26&amp;gt;    WHILE (@Counter&amp;gt;1) AND (@@FETCH_STATUS=0)&lt;br /&gt;
27&amp;gt;    BEGIN&lt;br /&gt;
28&amp;gt;          SELECT @Counter = @Counter - 1&lt;br /&gt;
29&amp;gt;          FETCH PRIOR FROM CursorTest INTO @OrderID, @CustomerID&lt;br /&gt;
30&amp;gt;          PRINT &amp;quot;Row &amp;quot; + CONVERT(varchar,@Counter) + &amp;quot; has an OrderID of &amp;quot; +&lt;br /&gt;
31&amp;gt;          CONVERT(varchar,@OrderID) + &amp;quot; and a CustomerID of &amp;quot; + @CustomerID&lt;br /&gt;
32&amp;gt;    END&lt;br /&gt;
33&amp;gt;&lt;br /&gt;
34&amp;gt;    CLOSE CursorTest&lt;br /&gt;
35&amp;gt;    DEALLOCATE CursorTest&lt;br /&gt;
36&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop PROCEDURE spCursorScroll;&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;
== FETCH NEXT FROM==&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; CREATE TABLE Employees(&lt;br /&gt;
5&amp;gt; empid   int         NOT NULL,&lt;br /&gt;
6&amp;gt; empname varchar(10) NOT NULL,&lt;br /&gt;
7&amp;gt; deptno  int         NULL ,&lt;br /&gt;
8&amp;gt; jobid   int         ,&lt;br /&gt;
9&amp;gt; salary decimal(7,2) NOT 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; INSERT INTO Employees VALUES(1, &amp;quot;Leo&amp;quot;, 400, 30, 3456.00)&lt;br /&gt;
3&amp;gt; INSERT INTO Employees VALUES(2, &amp;quot;Ros&amp;quot;, 200, 20, 4325.00)&lt;br /&gt;
4&amp;gt; INSERT INTO Employees VALUES(3, &amp;quot;Chris&amp;quot;, 100, 10, 8952.00)&lt;br /&gt;
5&amp;gt; INSERT INTO Employees VALUES(4, &amp;quot;Rob&amp;quot;, 400, 30, 1234.00)&lt;br /&gt;
6&amp;gt; INSERT INTO Employees VALUES(5, &amp;quot;Linda&amp;quot;, 400, 30, 4567.00)&lt;br /&gt;
7&amp;gt; INSERT INTO Employees VALUES(6, &amp;quot;Lisa&amp;quot;, NULL, 30, 8765.00)&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;     DECLARE&lt;br /&gt;
2&amp;gt;          @empname VARCHAR(40),&lt;br /&gt;
3&amp;gt;          @salary MONEY,&lt;br /&gt;
4&amp;gt;          @empid integer&lt;br /&gt;
5&amp;gt;     DECLARE getemp_curs CURSOR&lt;br /&gt;
6&amp;gt;         FOR&lt;br /&gt;
7&amp;gt;            SELECT empid, empname, salary FROM employees WHERE empid = 1&lt;br /&gt;
8&amp;gt;     OPEN getemp_curs&lt;br /&gt;
9&amp;gt;     FETCH NEXT FROM getemp_curs into @empid, @empname, @salary&lt;br /&gt;
10&amp;gt;     WHILE @@FETCH_STATUS = 0 BEGIN&lt;br /&gt;
11&amp;gt;          UPDATE employees SET salary = @salary WHERE empid = @empid&lt;br /&gt;
12&amp;gt;     FETCH NEXT FROM getemp_curs into @empid, @empname, @salary&lt;br /&gt;
13&amp;gt;     END&lt;br /&gt;
14&amp;gt;     CLOSE getemp_curs&lt;br /&gt;
15&amp;gt;     DEALLOCATE getemp_curs&lt;br /&gt;
16&amp;gt;     GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Employees;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== The syntax of the FETCH statement==&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;
FETCH [NEXT|PRIOR|FIRST|LAST|ABSOLUTE n|RELATIVE n]&lt;br /&gt;
FROM [GLOBAL] cursor_name&lt;br /&gt;
[INTO @variable_name [, ...]]&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>