
给你个例子你照着写就行了
table1结构如下
id
int
name
varchar(50)
declare
@id
int
declare
@name
varchar(50)
declare
cursor1
cursor
for
--定义游标cursor1
select
from
table1
--使用游标的对象(跟据需要填入select文)
open
cursor1
--打开游标
fetch
next
from
cursor1
into
@id,@name
--将游标向下移1行,获取的数据放入之前定义的变量@id,@name中
while
@@fetch_status=0
--判断是否成功获取数据
begin
update
table1
set
name=name+'1'
where
id=@id
--进行相应处理(跟据需要填入SQL文)
fetch
next
from
cursor1
into
@id,@name
--将游标向下移1行
end
close
cursor1
--关闭游标
deallocate
cursor1
--释放游标
在数据库中,游标提供了一种对从表中检索出的数据进行 *** 作的灵活手段。就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。
游标总是与一条SQL
选择语句相关联因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。
游标关于数据库中的 *** 作会对整个行集产生影响。由 SELECT 语句返回的行集包括所有满足该语句 WHERE 子句中条件的行。由语句所返回的这一完整的行集被称为结果集。
应用程序,特别是交互式联机应用程序,并不总能将整个结果集作为一个单元来有效地处理。这些应用程序需要一种机制以便每次处理一行或一部分行。游标就是提供这种机制的结果集扩展。
扩展资料:
游标通过以下方式扩展结果处理:
1允许定位在结果集的特定行。
2从结果集的当前位置检索一行或多行。
3支持对结果集中当前位置的行进行数据修改。
4为由其他用户对显示在结果集中的数据库数据所做的更改提供不同级别的可见性支持。
5提供脚本、存储过程和触发器中使用的访问结果集中的数据的 Transact-SQL 语句。
参考资料来源:搜狗百科—游标
oracle动态游标问题: 游标查询的内容是 动态生成的,然后里面具体有多少个字段没办法事先知道,而动态游标赋值一定要用fetch到一个变量,有没办法把动态游标内容赋值到一个记录集或者表中,而这个表的字段和记录集字段是没办法预先定义好的,而是通过系统动态生成的!具体例子如下:declare-- Local variables herev_sql VARCHAR2(1024);cur SYS_REFCURSOR;v_column VARCHAR2(1024);v_exe VARCHAR2(1024);begin---v_sql 是通过一连串的复杂逻辑程序生成的动态内容的 在这里就简单写了v_sql:='select C_001,b_002,d_003 /具体有多少个字段没办法事先知道/from table1,table2 /具体有多少个字段没办法事先知道/tablen where 1=1 and /复杂条件/';v_column:= 'C_001+b_002/d_003';--这个变量也是通过复杂的逻辑生成的 没办法事先知道的 但是这里的字段都在 v_sql 中有v_column := replace(replace(REPLACE(v_column,'b_','cb_'),'c_','cc_'),,'c_','cd_');FOR i IN 1e_table(i);v_exe:='INSERT INTO table_a SELECT'|| v_column||' FROM dual' ; /这里的动态生成的/
以上就是关于SQL中用游标查询几个表的记录全部的内容,包括:SQL中用游标查询几个表的记录、sql中的游标是什么怎样用呢、oracle动态游标问题 有没办法获取动态游标中的字段信息!!!等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)