游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。游标总是与一条T_SQL 选择语句相关联因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。当决定对结果集进行处理时,必须声明一个指向该结果集的游标。
使用游标有四种基本的步骤:声明游标、打开游标、提取数据、关闭游标。
1.声明游标
同其它变量一样,我们也可以定义游标的访问类型:全局、共享、实例或局部,游标变量的命名规范建议也同其它变量一样。 declare my_cursor cursor keyset for select * from info
DECLARE CustomerCursor CURSOR FOR
SELECT acct_no,name,balance FROM customer WHERE province="北京";
2.打开游标
OPEN CustomerCursor;
3.提取数据
FETCH语句来取得数据。一条FETCH语句一次可以将一条记录放入程序员指定的变量中。已经声明并打开一个游标后,我们就可以将数据放入任意的变量中。在FETCH语句中您可以指定游标的名称和目标变量的名称。
--声明局部变量
declare @id int,@name varchar(20),@address varchar(20)
--定位到指定位置的记录
fetch absolute 56488 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录相对位置记录
fetch relative -88 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录前一条
fetch prior from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录后一条
fetch next from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到首记录
fetch first from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到尾记录
fetch last from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
注:如果提示“提取类型··不能用于只进游标”则在声明游标时:DECLARE MyCursor CURSOR SCROLL FOR ·· (FAST_FORWARD :只进游标 ; SCROLL: 滚动游标 )
示例:
DECLARE MyCursor CURSOR SCROLL FOR SELECT * FROM Test1
DECLARE @ROW1 int,@ROW2 char(10),@ROW3 char(10),@ROW4 char(10)
OPEN MyCursor
FETCH next FROM MyCursor INTO @ROW1, @ROW2, @ROW3, @ROW4
WHILE (@@fetch_status =0)
BEGIN
INSERT INTO Test1(id, a, b, c)
VALUES (@ROW1, @ROW2, @ROW3, @ROW4)
FETCH next FROM MyCursor INTO @ROW1, @ROW2, @ROW3, @ROW4
END
CLOSE MyCursor
DEALLOCATE MyCursor
(示例是将Test1表中的数据复制一次!)
(@@fetch_status 返回被 fetch 语句执行的最后游标的状态,而不是任何当前被连接打开的游标的状态。0 fetch 语句成功;-1 fetch语句失败或此行不在结果集中;-2 被提取的行不存在;所以使用@@fetch_status=0判断是否游标到了最后一行)
高级应用:
修改当前游标所在行的信息,我们可以如下操作:
UPDATE table1
SET balance=1000
WHERE CURRENT of yourCursor;
删除当前行的操作如下:
DELETE FROM table1
WHERE CURRENT OF yourCursor;
此时声明游标的时候:declare my_cursor cursor scroll dynamic for ···
scroll表示可随意移动游标指针(否则只能向前),dynamic表示可以读写游标(否则游标只读)
相关推荐
Oracle数据库游标是数据库管理系统中用于处理查询结果的一种机制,它允许程序逐行处理查询结果,而不是一次性加载所有数据。在Oracle中,游标对于实现复杂的数据操作和控制流程至关重要,特别是在存储过程和触发器中...
数据库游标是数据库管理系统中的一个重要概念,主要用于处理和操作数据集。在Oracle数据库中,游标扮演着不可或缺的角色,尤其在进行复杂的SQL操作和程序逻辑控制时。本小练习主要目的是帮助你理解和掌握如何在...
数据库游标的使用 数据库游标是数据库系统中的一种机制,允许开发者逐行地读取查询结果集,并对每一行记录进行操作。下面是关于数据库游标的使用的详细知识点: 1. 为什么要使用游标? 在查询结果集中逐行地读取...
Oracle数据库中的游标是PL/SQL编程中一种重要的控制结构,它允许程序逐行处理查询结果,而不是一次性处理所有结果。游标对于处理大量数据或需要根据每行数据执行不同操作的情况非常有用。以下是关于Oracle游标使用的...
Oracle 数据库游标的使用方法 Oracle 数据库游标是指在查询返回结果超过一行时,需要使用的显式游标。用户不能使用 select into 语句,而是需要使用游标来处理多行查询结果。在 PL/SQL 中,隐式游标会在查询开始时...
oracle数据库游标实验报告!oracle数据库游标实验报告!oracle数据库游标实验报告!
### 数据库游标使用详解:Oracle数据库视角 在数据库领域,游标(Cursor)是一种用于处理数据查询结果集的强大工具,尤其在Oracle数据库中,游标的应用极为广泛且功能强大。本文将深入探讨Oracle数据库中游标的基本...
Oracle数据库游标是数据库编程中的一个重要概念,尤其在处理大量数据时,它们提供了一种有效且灵活的方法。游标允许程序逐行访问查询结果集,而不是一次性加载所有数据。这在处理复杂的数据操作,如循环处理、条件...
整理的Oracle数据库游标使用大全 SQL是用于访问ORACLE数据库的语言,PL/SQL扩展和加强了SQL的功能,它同时引入了更强的程序逻辑。 PL/SQL支持DML命令和SQL的事务控制语句。DDL在PL/SQL中不被支持,这就意味作在PL/...
MySql存储过程,游标的使用方法,速度极快!
数据库游标使用方法 数据库游标是系统为用户开设的一个数据缓冲区,存放 SQL 语句的执行结果。由系统或用户以变量的形式定义。用户可以用 SQL 语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理,主...
### 数据库游标:探索数据世界的导航仪 #### 引言:数据库游标的基本概念 在数据库领域,游标(Cursor)是一个极为重要的概念。它为开发者提供了一种高效且灵活的方式来与数据交互,尤其在处理大型数据集或执行...
在SQL Server中,数据库游标和函数是两个非常重要的概念,它们在数据处理和数据库操作中扮演着不可或缺的角色。游标允许我们逐行处理查询结果,而函数则提供了丰富的计算和逻辑处理能力。 首先,让我们深入理解SQL ...
Oracle数据库游标使用大全
Oracle 数据库游标、存储过程和触发器 Oracle 数据库是一种关系型数据库管理系统,它提供了多种机制来提高数据库的性能和安全性。在本文中,我们将讨论 Oracle 数据库中的三个重要概念:游标、存储过程和触发器。 ...
数据库游标是数据库管理系统提供的一种机制,允许程序员按需逐行处理查询结果集,而非一次性处理整个结果集。在SQL中,游标尤其在处理复杂逻辑和交互式应用时非常有用,例如需要对数据集进行迭代处理、条件判断或...
数据库游标是管理和应用开发中不可或缺的工具,它提供了一种高效且灵活的方式来处理数据库中的数据。通过正确地声明、打开、获取数据、关闭以及释放游标,开发者可以最大化地利用数据库的性能,同时保持代码的简洁性...