首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何获取受存储过程影响的记录数?

如何获取受存储过程影响的记录数?
EN

Stack Overflow用户
提问于 2009-07-29 16:06:52
回答 4查看 168.6K关注 0票数 90

对于直接针对数据库执行的INSERTUPDATEDELETE SQL语句,大多数数据库提供程序都会返回受影响的行数。对于存储过程,受影响的记录数始终为-1

我们如何获得受存储过程影响的记录数?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2009-07-29 16:12:18

为存储过程注册out参数,如果使用SQL Server,则根据@@ROWCOUNT设置值。如果您使用的是Oracle,请使用SQL%ROWCOUNT

请注意,如果您有多个INSERT/UPDATE/DELETE,则需要一个变量来存储每个操作的@@ROWCOUNT结果。

票数 83
EN

Stack Overflow用户

发布于 2009-07-29 17:51:58

@@RowCount会给出受一条SQL语句影响的记录数。

仅当您随后立即发出@@RowCount时,它才能工作。因此,如果您要捕获错误,则必须在同一行上执行。如果你把它分开,你就会错过你放在第二位的那个。

SELECT @NumRowsChanged = @@ROWCOUNT, @ErrorCode = @@ERROR

如果有多条语句,则必须捕获每条语句受影响的行数并将其相加。

SELECT @NumRowsChanged = @NumRowsChanged  + @@ROWCOUNT, @ErrorCode = @@ERROR
票数 46
EN

Stack Overflow用户

发布于 2009-07-29 16:09:47

对于Microsoft SQL Server,可以返回@@ROWCOUNT变量,以返回受存储过程中最后一条语句影响的行数。

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

https://stackoverflow.com/questions/1201358

复制
相关文章

相似问题

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