sqlserver事务的用法
来源:互联网 发布:正装皮鞋牌子 知乎 编辑:程序博客网 时间:2024/04/28 03:05
用法
事务(Transaction)是并发控制的单位,是用户定义的一个操作序列。这些操作要么都做,要么都不做,是一个不可分割的工作单位。
通过事务,SQL Server能将逻辑相关的一组操作绑定在一起,以便服务器保持数据的完整性。
现在通过一个典型的银行转账的例子来说明一下
首先创建一个表:
create database aaaa --创建一个表,包含用户的帐号和钱数gouse aaaacreate table bb(ID int not null primary key, --帐号moneys money --转账金额)insert into bb values ('1','2000') --插入两条数据insert into bb values ('2','3000')
用这个表创建一个存储过程:
create procedure mon --创建存储过程,定义几个变量@toID int, --接收转账的账户@fromID int , --转出自己的账户@momeys money --转账的金额asbegin tran --开始执行事务 update bb set moneys=moneys-@momeys where ID=@fromID -执行的第一个操作,转账出钱,减去转出的金额update bb set moneys=moneys+@momeys where ID=@toID --执行第二个操作,接受转账的金额,增加 if @@error<>0 --判断如果两条语句有任何一条出现错误begin rollback tran –开始执行事务的回滚,恢复的转账开始之前状态return 0endgo else --如何两条都执行成功begin commit tran 执行这个事务的操作return 1endgo
sqlserver事务与回滚
set XACT_ABORT ON ---如果不设置该项为ON,在sql中默认为OFF,那么只只回滚产生错误的 Transact-SQL 语句;设为ON,回滚整个事务begin tran t1 ---启动一个事务update [water].[dbo].[ErrorInf]set ErrorMessage='test'where ID=6insert into [water].[dbo].[ErrorInf]([ID],ErrorMessage,[Description])Values(1,'test1','test1')commit tran t1 ---提交事务
功能:实现begin tran 和commit tran之间的语句,任一如果出现错误,所有都不执
事务不是有错就回滚的,在不写rollback的情况下,并不是什么错误都会回滚事务,有时回滚当前语句,有时回滚整个事务
如例
begin tran insert into dbo.area values('1111')insert into dbo.area values('2222')select 1/0insert into dbo.area values('333')commit
像这样,就算中间有错,也不会回滚,结果会成功添加三条记录
但有人说,比如重大错误,这事务也会所有回滚,只是我无法重现重大错误罢了
普通错误如果想回滚整个事务,只要加个set XACT_ABORT on就可以了
set XACT_ABORT onbegin traninsert into dbo.area values('1111')insert into dbo.area values('2222')select 1/0insert into dbo.area values('333')commit
后来发现sql2005支持try
BEGIN TRY BEGIN TRANSACTION insert into dbo.area values('1111') insert into dbo.area values('2222') select 1/0 insert into dbo.area values('333') COMMITEND TRYBEGIN CATCH IF @@TRANCOUNT > 0 ROLLBACK DECLARE @ErrMsg nvarchar(4000), @ErrSeverity int SELECT @ErrMsg = ERROR_MESSAGE(), @ErrSeverity = ERROR_SEVERITY() RAISERROR(@ErrMsg, @ErrSeverity, 1)END CATCH
- sqlserver事务的用法
- sqlserver事务的用法
- sqlserver事务的用法
- sqlserver事务的用法
- SqlServer 事务的用法
- SQLserver 事务的两种用法
- SQLServer--事务的创建
- SQLServer -- 事务的应用
- SqlServer 存储过程的事务
- SQLServer事务的隔离级别
- SQLServer事务的傻瓜讲解
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- Android上使用Canvas绘制文字
- 【PB】在PB中调用外部程序并判断其运行结束
- 离我们很远?NFC的实际用途测试。
- 三层架构(概念)
- 盘点2012年我们一起关注的NFC创新应用
- sqlserver事务的用法
- NFC:除了移动支付 我还能干这些!
- struts2升级注意几点
- Log and data area are not compatible because 'Restart position not found
- Java将一段逗号分割的字符串转换成一个数组
- 每日一植物(二) -- 芦荟
- android 检查GPS是否开启,GPS设置界面
- 关于typedef的用法总结
- Dispatcher initialization failed