首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >不允许删除行的SQL Server触发器

不允许删除行的SQL Server触发器
EN

Stack Overflow用户
提问于 2017-01-29 05:25:02
回答 1查看 77关注 0票数 1

我正在读一些触发器的代码。

代码语言:javascript
运行
复制
CREATE TRIGGER No_DeleteCustomers
ON Customers
INSTEAD OF DELETE
AS
    IF @@ROWCOUNT = 0 
       RETURN

    RAISERROR('No deleting allowed', 11, 1)

但是我很困惑。@@ROWCOUNT不是用来显示最后一条语句中受影响的行数的吗?这如何阻止我从表中删除行?

EN

回答 1

Stack Overflow用户

发布于 2017-01-29 16:50:56

让我们逐行遍历触发器的代码来演示它是如何工作的:

代码语言:javascript
运行
复制
IF @@ROWCOUNT = 0                  -- if the number of rows to be deleted is 0 then...
    RETURN                         -- return
                                   -- if still running... 
RAISERROR('No deleting allowed', 11, 1)  -- raise an error to the caller

希望这能有所帮助!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41914990

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档