对于直接针对数据库执行的INSERT
、UPDATE
和DELETE
SQL语句,大多数数据库提供程序都会返回受影响的行数。对于存储过程,受影响的记录数始终为-1
。
我们如何获得受存储过程影响的记录数?
发布于 2009-07-29 16:12:18
为存储过程注册out参数,如果使用SQL Server,则根据@@ROWCOUNT
设置值。如果您使用的是Oracle,请使用SQL%ROWCOUNT
。
请注意,如果您有多个INSERT/UPDATE/DELETE
,则需要一个变量来存储每个操作的@@ROWCOUNT
结果。
发布于 2009-07-29 17:51:58
@@RowCount
会给出受一条SQL语句影响的记录数。
仅当您随后立即发出@@RowCount
时,它才能工作。因此,如果您要捕获错误,则必须在同一行上执行。如果你把它分开,你就会错过你放在第二位的那个。
SELECT @NumRowsChanged = @@ROWCOUNT, @ErrorCode = @@ERROR
如果有多条语句,则必须捕获每条语句受影响的行数并将其相加。
SELECT @NumRowsChanged = @NumRowsChanged + @@ROWCOUNT, @ErrorCode = @@ERROR
发布于 2009-07-29 16:09:47
对于Microsoft SQL Server,可以返回@@ROWCOUNT
变量,以返回受存储过程中最后一条语句影响的行数。
https://stackoverflow.com/questions/1201358
复制相似问题