sql server 游标 示例代码 路径表示法

Mark jiaguoxinzhi linyee

因为sql用得少,,经常会忘记怎么写。。

找得多了,,不如自己整个简单的标例,备忘。

 

declare @chlid bigint  --定义变量用于保存游标对应记录的值
declare @pPath varchar --定义变量
declare cur2 cursor for select channelid,ChannelPath from dbo.Channel where ChannelDeep=2 --游标指向记录集
open cur2 --打开
    fetch next from cur2 into @chlid,@pPath --获取下一句,,
    while @@FETCH_STATUS=0 --状态未结束?
    begin
        --print @chlid
        --print @pPath
        update dbo.Channel set ChannelDeep=3,ChannelPath=@pPath+CAST(ChannelParent as varchar(20))+'/' where ChannelParent=@chlid --执行更新
        fetch next from cur2 into @chlid,@pPath --继续获取下一句
    end
close cur2 --关闭
deallocate cur2 --释放

路径中含本身

--UPDATE [dbo].[Channel]   SET [ChannelDeep] = 0 ,[ChannelPath] ='/'+CAST(ChannelId as varchar(20))+'/' WHERE ChannelParent=0

declare @chlid bigint  --定义变量用于保存游标对应记录的值
declare @pPath varchar --定义变量
declare cur1 cursor for select channelid,ChannelPath from dbo.Channel where ChannelDeep=2 --游标指向记录集
open cur1 --打开
    fetch next from cur1 into @chlid,@pPath --获取下一句,,
    while @@FETCH_STATUS=0 --状态未结束?
    begin
        --print @chlid
        --print @pPath
        update dbo.Channel set ChannelDeep=3,ChannelPath=@pPath+CAST(ChannelId as varchar(20))+'/' where ChannelParent=@chlid --执行更新
        fetch next from cur1 into @chlid,@pPath --继续获取下一句
    end
close cur1 --关闭
deallocate cur1 --释放
GO

再完善点点

declare @chlid bigint  --定义变量用于保存游标对应记录的值
declare @pPath varchar(255) --定义变量


SET nocount ON                   --忽略行数显示

declare cur1 cursor  --声明游标
for select channelid,ChannelPath from dbo.Channel where ChannelDeep=3 --游标指向记录集
open cur1 --打开

    fetch next from cur1 into @chlid,@pPath --获取下一句,,
    while @@FETCH_STATUS=0 --状态未结束?
    begin
        print @chlid
        print @pPath
        update dbo.Channel set ChannelDeep=4,ChannelPath=@pPath+CAST(ChannelId as varchar(20))+'/' where ChannelParent=@chlid --执行更新
        fetch next from cur1 into @chlid,@pPath --继续获取下一句
    end
close cur1 --关闭
deallocate cur1 --释放

SET nocount OFF      --打开计数

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
测试3条数据 CREATE TABLE test_main ( id INT, value VARCHAR(10), PRIMARY KEY(id) ); INSERT INTO test_main(id, value) VALUES (1, 'ONE'); INSERT INTO test_main(id, value) VALUES (2, 'TWO'); INSERT INTO test_main(id, value) VALUES (3, 'THREE'); 简单循环处理 DECLARE @id INT, @value VARCHAR(10); BEGIN -- 定义游标. DECLARE c_test_main CURSOR FAST_FORWARD FOR SELECT id, value FROM test_main; -- 打开游标. OPEN c_test_main; --填充数据. FETCH NEXT FROM c_test_main INTO @id, @value; --假如检索到了数据,才处理. WHILE @@fetch_status = 0 BEGIN PRINT @value; --填充下一条数据. FETCH NEXT FROM c_test_main INTO @id, @value; END; -- 关闭游标 CLOSE c_test_main; --释放游标. DEALLOCATE c_test_main; END; go ONE TWO THREE 用于更新的游标 DECLARE @id INT, @value VARCHAR(10); BEGIN --定义游标. DECLARE c_test_main CURSOR FOR SELECT id, value FROM test_main FOR UPDATE; --打开游标. OPEN c_test_main; --填充数据. FETCH NEXT FROM c_test_main INTO @id, @value; --假如检索到了数据,才处理. WHILE @@fetch_status = 0 BEGIN PRINT @value; --更新数据. UPDATE test_main SET value = value + '1' WHERE CURRENT OF c_test_main; --填充下一条数据. FETCH NEXT FROM c_test_main INTO @id, @value; END; --关闭游标 CLOSE c_test_main; --释放游标. DEALLOCATE c_test_main; END; go ONE (1行受影响) TWO Three SELECT * FROM test_main; go id value ----------- ---------- 1 ONE1 2 TWO1 3 Three1 (3 行受影响) 支持来回滚动的游标 注:这里为了测试,将 test_main 表的数据,增加至11条。 DECLARE @id INT, @value VARCHAR(10); BEGIN -- 定义游标. DECLARE c_test_main CURSOR SCROLL FOR SELECT id, value FROM test_main; -- 打开游标. OPEN c_test_main; -- 填充数据. FETCH FIRST FROM c_test_main INTO @id, @value; PRINT '游标中的第一行:' + @value; -- 填充数据. FETCH LAST FROM c_test_main INTO @id, @value; PRINT '游标中的最后一行:' + @value; -- 填充数据. FETCH ABSOLUTE 3 FROM c_test_main INTO @id, @value; PRINT '游标中的第3行[绝对地址]:' + @value; -- 填充数据. FETCH RELATIVE -2 FROM c_test_main INTO @id, @value; PRINT '游标中的第-2行[相对地址]:' + @value; -- 填充数据. FETCH PRIOR FROM c_test_main INTO @id, @value; PRINT '游标中的上一行:' + @value; -- 填充数据. FETCH NEXT FROM c_test_main INTO @id, @value; PRINT '游标中的下一行:' + @value; -- 关闭游标 CLOSE c_test_main; -- 释放游标. DEALLOCATE c_test_main; END; go 小结 SQL-92语法 DECLARE cursor_name [ INSENSITIVE ] [ SCROLL ] CURSOR FOR select_statement [ FOR { READ ONLY | UPDATE [ OF column_name [ ,...n ] ] } ] Transact-SQL扩展语法 DECLARE cursor_name CURSOR [ LOCAL | GLOBAL ] [ FORWARD_ONLY | SCROLL ] [ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ] [ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ] [ TYPE_WARNING ] FOR select_statement [ FOR UPDATE [ OF column_name [ ,...n ] ] ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

灵易联盟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值