sqlserver游标使用步骤示例(创建游标 关闭游标)

游标(cursor)是一个存储在DBMS服务器上的数据库查询,它不是一条SELECT语句,而是被该语句检索出来的结果集。在存储了游标之后,应用程序可以根据需要滚动或浏览其中的数据。

使用游标

使用游标的步骤:

在使用游标前,必须声明(定义)它。这个过程实际上没有检索数据,它只是定义要使用的SELECT语句和游标选项。
一旦声明,就必须打开游标以供使用。这个过程用前面定义的SELECT语句把数据实际检索出来。
对于填有数据的游标,根据需要取出(检索)各行。
在结束游标使用时,必须关闭游标,可能的话,释放游标(有赖于具体的DBMS)。
声明游标后,可根据需要频繁地打开和关闭游标。在游标打开时,可根据需要频繁地执行取操作。

创建游标

在SQL Server中使用DECLARE命名游标,并定义相应的SELECT语句,根据需要带WHERE和其他子句,示例如下:
复制代码 代码如下:
DECLARE CustCursor CURSOR
FOR
SELECT * FROM Customers
WHERE cust_email IS NULL

使用游标

使用OPEN CURSOR语句打开游标,使用FETCH语句访问游标数据了。FETCH指出要检索哪些行,从何处检索它们以及将它们放于何处(如变量名),下面是SQL Server中使用游标的示例:

复制代码 代码如下:
DECLARE @cust_id CHAR(10),
@cust_name CHAR(50),
@cust_address CHAR(50),
@cust_city CHAR(50),
@cust_state CHAR(5),
@cust_zip CHAR(10),
@cust_country CHAR(50),
@cust_contact CHAR(50),
@cust_email CHAR(255)
OPEN CustCursor
FETCH NEXT FROM CustCursor
INTO @cust_id, @cust_name, @cust_address,
@cust_city, @cust_state, @cust_zip,
@cust_country, @cust_contact, @cust_email
WHILE @@FETCH_STATUS = 0
BEGIN

FETCH NEXT FROM CustCursor
INTO @cust_id, @cust_name, @cust_address,
@cust_city, @cust_state, @cust_zip,
@cust_country, @cust_contact, @cust_email
...
END
CLOSE CustCursor

在此例中,为每个检索出的列声明一个变量,FETCH语句检索一行并保存值到这些变量中。使用WHILE循环处理每一行,条件WHILE @@FETCH_STATUS = 0在取不出更多的行时终止处理(退出循环)。这个例子也不进行具体的处理,实际代码中,应该用具体的处理代码替换其中的…占位符。

关闭游标

SQL Server 中关闭游标:
复制代码 代码如下:
CLOSE CustCursor
DEALLOCATE CURSOR CustCursor

CLOSE语句用来关闭游标。一旦游标关闭,如果不再次打开,将不能使用。第二次使用它时不需要再声明,只需用OPEN打开它即可。

时间: 2024-10-26 02:57:42

sqlserver游标使用步骤示例(创建游标 关闭游标)的相关文章

sqlserver游标使用步骤示例(创建游标 关闭游标)_MsSql

游标(cursor)是一个存储在DBMS服务器上的数据库查询,它不是一条SELECT语句,而是被该语句检索出来的结果集.在存储了游标之后,应用程序可以根据需要滚动或浏览其中的数据. 使用游标 使用游标的步骤: 在使用游标前,必须声明(定义)它.这个过程实际上没有检索数据,它只是定义要使用的SELECT语句和游标选项.一旦声明,就必须打开游标以供使用.这个过程用前面定义的SELECT语句把数据实际检索出来.对于填有数据的游标,根据需要取出(检索)各行.在结束游标使用时,必须关闭游标,可能的话,释放

mssql 打开游标 关闭游标 删除游标

  declare @mergedate datetime declare @masterid int declare @duplicateid int select @mergedate = getdate() declare merge_cursor cursor fast_forward for select mastercustomerid, duplicatecustomerid from duplicatecustomers where ismerged = 0 --定义一个游标对象

Oracle游标共享(Cursor Sharing)--常规游标共享和自适应游标共享(ACS)

Oracle游标共享(Cursor Sharing)--常规游标共享和自适应游标共享(ACS) 游标共享(Cursor Sharing)是指Shared Cursor间的共享,其实就是重用存储在Child Cursor中的解析树和执行计划而不用从头开始做硬解析的动作.特别对于除SQL文本中对应的输入值不同外,其它部分都一模一样的目标SQL更应该实现游标共享,而使用绑定变量就可以实现游标共享. 很多OLTP类型的应用系统的开发人员在开发阶段并未意识到硬解析的危害,所以也没有使用绑定变量,等到系统上

性能优化——统计信息——SQLServer自动更新和自动创建统计信息选项

原文:性能优化--统计信息--SQLServer自动更新和自动创建统计信息选项 原文译自:http://www.mssqltips.com/sqlservertip/2766/sql-server-auto-update-and-auto-create-statistics-options/?utm_source=dailynewsletter&utm_medium=email&utm_content=headline&utm_campaign=2012913          

类中数据库访问-求php开发中数据库连接创建和关闭的较好时机问题

问题描述 求php开发中数据库连接创建和关闭的较好时机问题 刚刚学php不久,在用php写一个毕业设计,可是在数据库连接的地方犯了难, 最开始用的是配置文件的方法, 在config.inc.php中设置了数据库连接的一些参数,比如说数据库名密码等等, 然后在db.conn.php中创建一个mysqli对象,连接上数据库,并设置它的编码. 后来在应用的过程中发现特别麻烦,每次都要用include将这些文件导入,然后再使用 $db进行数据库的访问,可是后来在一些类中处理,打算在构造函数中创建数据库连

《UNIXLinux程序设计教程》一3.1 文件描述字的打开、创建和关闭

3.1 文件描述字的打开.创建和关闭 函数open()或create()用于打开或创建一个文件描述字. #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> int open (const char * filename, int flags [, mode_t mode]); int create (const char * filename, mode_t mode); open()用于打开或

ASP调用SqlServer存储过程的经典示例(原创)

ASP调用SqlServer存储过程的经典示例 1.无输入参数,无返回值这种方式比较少见,但也是一种情况.ConnString="Dsn=DsnName;Uid=user;Pass=pass"Set Conn = Server.CreateObject("Adodb.Connection")Conn.Open ConnStringConn.Execute "ProcName" 2.两个输入参数,无返回值ConnString="Dsn=D

sqlserver 游标的简单示例_MsSql

Declare @Id varchar(20) Declare @Name varchar(20) Declare Cur Cursor For select substring(id,0,7) as id,name from temp1 Open Cur Fetch next From Cur Into @Id,@Name While @@fetch_status=0 Begin Update temp Set [c3]=@Name where [id] like @Id+'%' Fetch

sqlserver 游标的简单示例

Declare @Id varchar(20) Declare @Name varchar(20) Declare Cur Cursor For select substring(id,0,7) as id,name from temp1 Open Cur Fetch next From Cur Into @Id,@Name While @@fetch_status=0 Begin Update temp Set [c3]=@Name where [id] like @Id+'%' Fetch