这个(简单的)sql 事务有什么问题?

发布于 2024-11-16 17:39:03 字数 300 浏览 0 评论 0原文

“else”部分总是在sql中执行,知道为什么吗?

use myDB
GO


begin TRANSACTION
go
declare @rowtoalter int =1

update myTempTable set name='newName' where userid=1

if(@@ROWCOUNT=@rowtoalter)
begin
    commit
    print N'yes it works'
end
else
begin
    rollback
    print N'nooo'
end 

GO

the "else" section is always executed in the sql, any idea why?

use myDB
GO


begin TRANSACTION
go
declare @rowtoalter int =1

update myTempTable set name='newName' where userid=1

if(@@ROWCOUNT=@rowtoalter)
begin
    commit
    print N'yes it works'
end
else
begin
    rollback
    print N'nooo'
end 

GO

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

醉殇 2024-11-23 17:39:03

您更改的行数少于或多于一行,因为 userid=1 有零行或 2 行以上。 SELECT COUNT(*) FROM myTempTable WHERE userid=1 给出了什么?

我刚刚测试了在哪里更新一行完全,我得到“是的,它有效”

You are altering less than or more than one row because you have zero or 2+ rows for userid=1. What does SELECT COUNT(*) FROM myTempTable WHERE userid=1 give?

I've just tested where I update one row exactly and I get "yes it works"

雨后彩虹 2024-11-23 17:39:03

为什么不直接将检查合并到您的更新中:

declare @rowtoalter int =1

update myTempTable set name='newName' where userid=1
and (select count(*) from myTempTable where userid=1)=@rowtoalter

why not just incorporate the check right into your update:

declare @rowtoalter int =1

update myTempTable set name='newName' where userid=1
and (select count(*) from myTempTable where userid=1)=@rowtoalter
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文