如何避免这样的问题呢?有三种方法:
1. 在事务语句最前面加上set xact_abort on
- set xact_abort on
- begin tran
- update statement 1 ...
- update statement 2 ...
- delete statement 3 ...
- commit tran
- go
当xact_abort 选项为on 时,SQL Server在遇到错误时会终止执行并rollback 整个事务。
2. 在每个单独的DML语句执行后,立即判断执行状态,并做相应处理。
- begin tran
- update statement 1 ...
- if @@error <> 0
- begin rollback tran
- goto labend
- end
- delete statement 2 ...
- if @@error <> 0
- begin rollback tran
- goto labend
- end
- commit tran
- labend:
- go
3. 在SQL Server 2005中,可利用 try...catch 异常处理机制。
- begin tran
- begin try
- update statement 1 ...
- delete statement 2 ...
- endtry
- begin catch
- if @@trancount > 0
- rollback tran
- end catch
- if @@trancount > 0
- commit tran
- go
下面是个简单的存储过程,演示事务处理过程。
- create procedure dbo.pr_tran_inproc as begin set nocount on
- begin tran
- update statement 1 ...
- if @@error <> 0
- begin rollback tran
- return -1 end
- delete statement 2 ...
- if @@error <> 0
- begin rollback tran
- return -1
- end commit tran
- return 0
- end
- go
关于SQL Server数据库中在存储过程中编写正确的事务处理代码的方法就介绍到这里了,希望本次的介绍能够对您有所帮助。