存储过程里使用select要注意的一个问题!

经常写存储过程,使用select来返回一个数据集,今天偶然在存储过程中需要判断一个字段的值不能在一张表里重复,这个字段不是主键,我就用了select来查询,

然后用@@rowcount来判断是不是等于0,是的话直接用

select '2' as flag

结果返现老是返回2个select数据集出来,一个就是上面那个查询的,后来在各个位置测试都会这样,突然想到了,这本来就是sql数据库的一个机制,在存储过程中用select来查询数据都会返回,除非你把select后面查询的数据赋给一个变量,比如:

select @flag=name from **

这样就不会在调用存储过程作为返回集了,最后我用了一个投机取巧的办法来解决的:

update SysRole set RoleName=@RoleName where  RoleName=@RoleName

if @@rowcount=0

  实现

else

  ///实现

 

@RoleName这个参数是带入存储过程的变量。这样就解决我开始第一个select犯得问题了。

 

呵呵,一直没有注意过这个问题。

转载于:https://www.cnblogs.com/5566xzs/archive/2010/07/30/1788475.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值