MSSQL Server Transaction 数据库事务回滚的用法
2015-02-16 15:25
996 查看
使用的表结构如下:
Catch来捕获异常。
如果 TRY 块内生成的错误导致当前事务的状态失效,
则将该事务归类为不可提交的事务。
如果通常在 TRY 块外中止事务的错误在 TRY 内发生时,
就会导致事务进入不可提交状态。
不可提交的事务只能执行读操作或 ROLLBACK TRANSACTION。
该事务不能执行任何可能生成写操作或 COMMIT TRANSACTION 的 Transact-SQL 语句。
如果事务被分类为不可提交的事务,则 XACT_STATE 函数会返回值 -1。
*/
全部回滚方法3:自定义错误变量
Use TestDB
Declare @tranError int -- 定义变量
Set @tranError=0
Begin TransAction
Insert Into Person(PersonId,PersonName)
Values('1','Name1')
Set @tranError = @tranError + @@Error
Insert Into Person(PersonId,PersonName)
Values('1','Name1')
Set @tranError = @tranError + @@Error
Insert Into Person(PersonId,PersonName)
Values('3','Name3')
Set @tranError = @tranError + @@Error
If @tranError = 0
Commit TransAction
Else
Rollback TransAction
/*
自定义一个变量来判断最后是否发生过错误。
*/
最后要注意的是:如果一个事务写了 Begin TransAction 而没写 Commit TransAction 或 Rollback TransAction 则相关操作的数据(也许是表,也许是列,这我还没测试。。。)会被锁住。。。而对于锁住的解决办法就是单独执行一下Commit TransAction 或 Rollback TransAction
Catch来捕获异常。
如果 TRY 块内生成的错误导致当前事务的状态失效,
则将该事务归类为不可提交的事务。
如果通常在 TRY 块外中止事务的错误在 TRY 内发生时,
就会导致事务进入不可提交状态。
不可提交的事务只能执行读操作或 ROLLBACK TRANSACTION。
该事务不能执行任何可能生成写操作或 COMMIT TRANSACTION 的 Transact-SQL 语句。
如果事务被分类为不可提交的事务,则 XACT_STATE 函数会返回值 -1。
*/
全部回滚方法3:自定义错误变量
Use TestDB
Declare @tranError int -- 定义变量
Set @tranError=0
Begin TransAction
Insert Into Person(PersonId,PersonName)
Values('1','Name1')
Set @tranError = @tranError + @@Error
Insert Into Person(PersonId,PersonName)
Values('1','Name1')
Set @tranError = @tranError + @@Error
Insert Into Person(PersonId,PersonName)
Values('3','Name3')
Set @tranError = @tranError + @@Error
If @tranError = 0
Commit TransAction
Else
Rollback TransAction
/*
自定义一个变量来判断最后是否发生过错误。
*/
最后要注意的是:如果一个事务写了 Begin TransAction 而没写 Commit TransAction 或 Rollback TransAction 则相关操作的数据(也许是表,也许是列,这我还没测试。。。)会被锁住。。。而对于锁住的解决办法就是单独执行一下Commit TransAction 或 Rollback TransAction
相关文章推荐
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- MSSQL Tran 数据库事务回滚的用法
- sql事务(Transaction)用法介绍及回滚实例
- mssql,procedure,tran,transaction,事务,数据库事务,获取上一次的ID
- 数据库中的事务处理详解SQL Server Transaction
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- sql事务(Transaction)用法介绍及回滚实例
- [转载]MS SQL Server数据库事务锁机制分析
- SQL Server TransAction 全部回滚
- SQL Server TransAction 全部回滚
- MS SQL Server和Oracle对数据库事务处理的差异性
- .net中的数据库事务回滚