
游标(cursor)是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果。每个游标区都有一个名字,用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理。游标提供了一种对从表中检索出的数据进行 *** 作的灵活手段。
使用游标的基本步骤:
1、声明游标。把游标与T-SQL语句的结果集联系起来。
2、打开游标。
3、使用游标 *** 作数据。
4、关闭游标。
功能:
1、游标提供了一种对从表中检索出的数据进行 *** 作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。
2、游标能够实现按与传统程序读取平面文件类似的方式处理来自基础表的结果集,从而把表中数据以平面文件的形式呈现给程序。
3、游标把作为面向集合的数据库管理系统和面向行的程序设计两者联系起来,使两个数据处理方式能够进行沟通。
种类:
1、Transact_SQL游标
Transact_SQL游标是由DECLARECURSOR语法定义、主要用在Transact_SQL脚本、存储过程和触发器中。Transact_SQL游标主要用在服务器上,由从客户端发送给服务器的Transact_SQL语句或是批处理、存储过程、触发器中的Transact_SQL进行管理。Transact_SQL游标不支持提取数据块或多行数据。
2、API游标
API游标支持在OLEDB,ODBC以及DB_library中使用游标函数,主要用在服务器上。每一次客户端应用程序调用API游标函数,MSSQLSEVER的OLEDB提供者、ODBC驱动器或DB_library的动态链接库(DLL)都会将这些客户请求传送给服务器以对API游标进行处理。
3、客户游标
客户游标主要是当在客户机上缓存结果集时才使用。在客户游标中,有一个缺省的结果集被用来在客户机上缓存整个结果集。客户游标仅支持静态游标而非动态游标。由于服务器游标并不支持所有的Transact-SQL语句或批处理,所以客户游标常常仅被用作服务器游标的辅助。因为在一般情况下,服务器游标能支持绝大多数的游标 *** 作。由于API游标和Transact-SQL游标使用在服务器端,所以被称为服务器游标,也被称为后台游标,而客户端游标被称为前台游标。
在数据库中,游标提供了一种对从表中检索出的数据进行 *** 作的灵活手段。就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。
游标总是与一条SQL
选择语句相关联因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。
游标关于数据库中的 *** 作会对整个行集产生影响。由 SELECT 语句返回的行集包括所有满足该语句 WHERE 子句中条件的行。由语句所返回的这一完整的行集被称为结果集。
应用程序,特别是交互式联机应用程序,并不总能将整个结果集作为一个单元来有效地处理。这些应用程序需要一种机制以便每次处理一行或一部分行。游标就是提供这种机制的结果集扩展。
扩展资料:
游标通过以下方式扩展结果处理:
1允许定位在结果集的特定行。
2从结果集的当前位置检索一行或多行。
3支持对结果集中当前位置的行进行数据修改。
4为由其他用户对显示在结果集中的数据库数据所做的更改提供不同级别的可见性支持。
5提供脚本、存储过程和触发器中使用的访问结果集中的数据的 Transact-SQL 语句。
参考资料来源:搜狗百科—游标
游标:
作用:通常情况下,
关系数据库
中的 *** 作总是对整个
记录
集产生影响,例如使用
SELECT语句
检索
数据表
时,将得到所有满足该
语句
where
子句
中
条件
的记录,而在实际应用
过程
中,经常需要
每次处理一条或者一部分记录。在这种情况下,需要使用游标在
服务器
内部
处理结果集合,他可
以有助于识别一个数据集合内部指定的记录,从而可以有选择的按记录执行 *** 作。
游标:
作用:通常情况下,关系数据库中的 *** 作总是对整个记录集产生影响,例如使用SELECT语句检索数据表时,将得到所有满足该语句where子句中条件的记录,而在实际应用过程中,经常需要
每次处理一条或者一部分记录。在这种情况下,需要使用游标在服务器内部处理结果集合,他可
以有助于识别一个数据集合内部指定的记录,从而可以有选择的按记录执行 *** 作。
游标是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果。每个游标区都有一个名字。用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理。主语言是面向记录的,一组主变量一次只能存放一条记录。仅使用主变量并不能完全满足SQL语句向应用程序输出数据的要求。嵌入式SQL引入了游标的概念,用来协调这两种不同的处理方式。在数据库开发过程中,当你检索的数据只是一条记录时,你所编写的事务语句代码往往使用SELECT INSERT 语句。但是我们常常会遇到这样情况,即从某一结果集中逐一地读取一条记录。那么如何解决这种问题呢?这时我们就会使用游标。
你是指ASP里面的数据库连接组件里面所属记录集的游标吧
如conn,1,1后面的参数什么的
简单说来:
CONN,1,1为只读数据;1,3为插入数据;2,3是修改数据
游标的意思形象的说一个表格里有许多行数据,我用鼠标指向某一行数据(在ASP里面叫记录集)你可以拖用鼠标指向下一行。在ASP里面同样也可以。不过要通过它:rsmovenext,记录集往下移。
至于具体和理论知识如下:
游标类型
Const adOpenForwardOnly = 0
前向游标,为缺省游标,提供最快的运行性能。用它打开recordset,从对至尾顺序取得所有结果。它不支持向后滚动,只允许在结果间单向移动。
Const adOpenKeyset = 1
静态游标,反映第一次打开游标时表中数据的状态,游标无法查明底层表中的数据行是否更新过、删除过或添加了新的数据。不过与只能前移的洲标不同,静态游标可以在结果间前后滚动。
Const adOpenDynamic = 2
键盘驱动的游标,可以查询表中底层数据行的某些变化,但不是全部。它特别是可以准确反映数据是否更新过。但它不能查明其它用户是否曾删除过数据行(删除掉的数据行在recordset中会留下空洞)。键盘驱动的游标支持在结果间前后滚动。
Const adOpenStatic = 3
动态游标,是最丰富的游标类型。游标打开时可以查询其他用户对表的任何改动,而且支持滚动。
加锁类型
Const adLockReadOnly = 1
缺省的上锁类型,只读方式上锁允许多个用户同时读取同样的数据,但不能改变数据。
Const adLockPessimistic = 2
以悲观上锁方式打开数据对象。该方式假定在你编辑记录时会有其它用户访问数据。此时一旦你开始编辑记录,其它用户就不能访问该数据。
Const adLockOptimistic = 3
以乐观上锁方式打开数据对象。该方式假定在你编辑记录时不会有其它用户访问数据。在完成改变之前,其它用户不能访问该记录。
Const adLockBatchOptimistic = 4
执行多行批处理更新时使用这种类型
declare
游标名
cursor
for
select语句
open
游标名
fetch
游标名
into
@变量1,@变量2,,@变量n--(变量个数要与select语句结果的个数一致)
while
(@@fetch_status
=
0)
begin
--处理代码
fetch
游标名
into
@变量1,@变量2,,@变量n
end
close
游标名
deallocate
游标名
end
现在的C#,以及java之类的语言已经是面向对象了,基本很少用到游标 因为逻辑处理,以及循环基本都在程序中体现出来 现在有用到游标的情况下,就是优化的时候会用到,比如:一个要循环插入值,所插入的值又在另外一张表中查询出来的,这时候,如果用程序去循环,务必会加重了程序与sql的负担,所以,创建一个存储过程是必须的。这时候就有可能用到游标了 游标最常用的时候是面向过程的编程中。。
以上就是关于什么是游标使用游标的基本步骤是什么全部的内容,包括:什么是游标使用游标的基本步骤是什么、sql中的游标是什么怎样用呢、SQL 数据库中的游标指的是什么,有什么作用等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)