sql server中如何判断游标是否存在

--测试
DECLARE @SNAME VARCHAR(20)
DECLARE DD  CURSOR FOR SELECT SNAME FROM S
OPEN DD
--楼上说的对.你要的是判断游标是否存在
select * from MASTER.dbo.syscursors where cursor_name='DD'
--以下操作为判断游标是否存在的同时检测游标状态。
SELECT (CASE WHEN CURSOR_STATUS('global','DD')=1 THEN '游标的结果集至少有一行'
            WHEN CURSOR_STATUS('global','DD')=0 THEN '游标的结果集为空'
            WHEN CURSOR_STATUS('global','DD')=-1 THEN '游标被关闭'
            WHEN CURSOR_STATUS('global','DD')=-2 THEN '游标不适用'
            WHEN CURSOR_STATUS('global','DD')=-3 THEN '游标不存在' END) AS RESULT
/*返回结果:
1
 游标的结果集至少有一行。

对于不区分的游标和键集游标,结果集至少有一行。

对于动态游标,结果集可以有零行、一行或多行。
 分配给该变量的游标已打开。

对于不区分的游标和键集游标,结果集至少有一行。

对于动态游标,结果集可以有零行、一行或多行。
 
0
 游标的结果集为空。*
 分配给该变量的游标已经打开,然而结果集肯定为空。*
 
-1
 游标被关闭。
 分配给该变量的游标被关闭。
 
-2
 不适用。
 可以是:

先前调用的过程并没有将游标分配给 OUTPUT 变量。

先前调用的过程为 OUTPUT 变量分配了游标,然而在过程结束时,游标处于关闭状态。因此,游标被释放,并且没有返回调用过程。

没有将游标分配给已声明的游标变量。
 
-3
 具有指定名称的游标不存在。
 具有指定名称的游标变量并不存在,或者即使存在这样一个游标变量,但并没有给它分配游标。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值