SQL游标

SQL游标游标(MSSQL)例子:银行取钱1000块钱方案:1ATM点击取款100010张2ATM点击取款100取10次遍历思想优点:允许你一个个的遍历缺点:效率非常的低注意:一般情况下,不要

大家好,又见面了,我是你们的朋友全栈君。

游标(MSSQL)

例子:银行取钱1000块钱

方案:1ATM点击取款1000 10张

2ATM点击取款100 取10次

遍历思想

优点:允许你一个个的遍历

缺点:效率非常的低

注意:一般情况下,不要使用游标。

 

语法:

declare cursor1(游标名) cursor for select XXX--声明游标 1
open XXXX--打开 2
fetch next from XXX into XXX--将游标值赋给XXX   3
while(@@fetch_status=0)--循环查找
fetch next from XXX into XXX--同上
close cursor1--关闭游标   4
deallocate cursor1--解散游标   5

fetch_status
0 FETCH 语句成功
-1 FETCH 语句失败或此行不在结果集中
-2 被提取的行不存在

eg:
alter PROCEDURE cursor_a_b_insert
@aId int,
@aName nchar(10)
AS

declare @id int
declare @name varchar(50)
declare cursor1 cursor
for --定义游标cursor1 select bid,bname from b where aid=@aId --使用游标的对象(跟据需要填入select文) open cursor1 --打开游标 fetch next from cursor1 into @id,@name --将游标向下移1行,获取的数据放入之前定义的变量@id,@name中 while @@fetch_status=0 --判断是否成功获取数据 begin update b set bname=@aName+'1' where bid=@id --进行相应处理(跟据需要填入SQL文) update a set aname=@aName where aid=@aId fetch next from cursor1 into @id,@name --将游标向下移1行 end close cursor1 --关闭游标 deallocate cursor1 exec cursor_a_b_insert 55,'王媛媛'





alter proc cursor_pr_UpUser
@NoteUserId int
as
begin transaction
declare @NLId int
declare @NPLId int
–创建用户所对应的日志游标cursorNLId,将日志id放入@NLId游标中
declare cursorNLId cursor for select NoteLogId from NoteLogs where NUId=@NoteUserId
open cursorNLId
fetch next from cursorNLId into @NLId

while @@fetch_status=0 –判断是否成功获取数据
begin
–创建日志所对应的评论游标cursorNPLId,将评论id放入@NPLId游标中
declare cursorNPLId cursor for select NotePingLunId from NotePingLun where NLId=@NLId
open cursorNPLId
fetch next from cursorNPLId into @NPLId
while @@fetch_status=0
begin
–根据评论游标@NPLId修改评论状态
update dbo.NoteReply set NoteDel=0 where NoteReplyId=@NPLId
fetch next from cursorNPLId into @NPLId
end
–当评论游标遍历完关闭
close cursorNPLId –关闭游标
deallocate cursorNPLId
–根据日志游标@NPLId修改日志状态
update dbo.NotePingLun set NoteDel=0 where NLId=@NLId
fetch next from cursorNLId into @NLId

end
–关闭日志游标
close cursorNLId –关闭游标
deallocate cursorNLId
–根据用户修改用户和日志状态
update dbo.NoteUser set NoteDel=0 where NoteuserId=@NoteUserId
update dbo.NoteLogs set NoteDel=’qq’ where NUId=@NoteUserId
if @@error<>0 –如果有错误
begin
print ‘删除失败,回滚事务’
rollback transaction –回滚
end
else
begin
print ‘删除成功,提交事务’
commit transaction
end
go


exec cursor_pr_UpUser 1

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154344.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号