怎么一行一行的遍历数据库中的所有行

怎么一行一行的遍历数据库中的所有行,第1张

使用【游标】可以辅助实现一行一行地遍历某个数据库表中的所有行。

例如在Oracle数据库中:

declare

sname varchar2( 20)--声明变量

cursor student_cursor is select sname from student --声明指向表student的【游标】

begin

open student_cursor--打开游标

fetch student_cursor into sname --获取游标的当前指向值,使游标指针往下移动

while student_cursor%found --判断游标指针是否指向某行记录,即是否已遍历完全表

loop--循环遍历

dbms_output.put_line ('学生姓名' ||sname )--输出当前遍历访问的行记录信息

fetch student_cursor into sname--获取游标的当前指向值,使游标指针往下移动

end loop--循环体结束

close student_cursor--关闭游标,对应前面open *** 作

end

1、查询数据库(test)中的所有表名的方法:

SELECT name

FROM [test]..sysobjects where xtype='U'

********

补充:

如果有的表不存在【时间】那就用下面的语句直接把含有【时间】列的表名找到:

SELECT d.name

FROM [test]..syscolumns a

inner join [test]..sysobjects d on a.id=d.id and d.xtype='U' and a.name='时间'

**********

2、遍历这个表名取出数据插入到另外的数据库中(SqlServer中的遍历方法我不是很清楚,给你提供个思路,oracle的话我就能把程序写出来了O(∩_∩)O~)。

如:遍历结果存储到数据库test2中

insert into [test2]..遍历出的表名 select * from 遍历出的表名 where datediff(day,'2009-08-07',时间)>0

重复上面的sql语句指导讲数据库test中的表名完全遍历完为止。

*************************************************************

补充:我试验了一下下面把实验代码给你(建一个存储过程)

create proc test as

--定义游标变量

declare cur1 cursor for

SELECT d.name

FROM [test]..syscolumns a

inner join [test]..sysobjects d on a.id=d.id and d.xtype='U' and a.name='时间'

--定义临时变量

declare @tmp varchar(1000)

--定义sql字符串

declare @strsql varchar(4000)

--打开游标

open cur1

--读取第一条数据,也就是第一个表名

fetch next from cur1 into @tmp

--是读完

while(@@fetch_status = 0)

begin

--连接sql文

set @strsql='insert into [test2]..'+@tmp++' select * from '+@tmp+' where datediff(day,'+char(39)+'2009-08-07'+char(39)+',时间)>0'

--执行这个sql

exec(@strsql)

--读取下一条数据

fetch next from cur1 into @tmp

end

--关闭游标

close cur1

--摧毁游标所占资源

deallocate cur1

*************************************************

---

以上,希望对你有所帮助。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10829028.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-11
下一篇 2023-05-11

发表评论

登录后才能评论

评论列表(0条)

保存