数据库中的事务~

一、事务的概念

用一句话简单的说明:数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作(对数据库的相关增删改查的操作),要么完全地执行,要么完全地不执行。

二、数据库事务的四大特性

数据库的四大特性ACID,原子性、一致性、隔离性、持久性。每个特性都有其特定的职责。

     2.1、原子性:一个事务中的所有操作,要不 操作全部成功,要不全部失败,不能存在中间态。

     2.2、一致性:事务必须使得数据库从一个一致性状态转变到另一个一致性状态。比如银行转账,A账户转到B账户,不管转几次,A和B账户的总额不能变。

     2.3、隔离性:是指多个用户同时请求数据库,开启多个事务同时处理某个数据库,隔离性保证了各个事务之间均不受干扰,每个事务都感觉不到其他事务的存在。

     2.4、持久性:对数据库的修改是持久性的,一旦修改,就算数据库系统出现故障,这种修改也不会丢失,这点是数据库数据存放到硬盘中,并有redo log 和 binlog 一起保证的。

三、 事务的语句

开始事物:BEGIN TRANSACTION
 提交事物:COMMIT TRANSACTION
 回滚事务:ROLLBACK TRANSACTION

例如:

新建一个事务:

begin Transaction tran_Change
declare @err_nums int
set @err_nums=0
begin try
update Customers set Remain=Remain-100 where ID=3
set @err_nums=@err_nums+@@ERROR
update Customers set Remain=Remain+100 where ID=5
set @err_nums=@err_nums+@@ERROR
end try
begin catch
  print'错误编号:'+convert(varchar,error_number())+'错误消息'+error_message()
  set @err_nums=@err_nums+1
end catch

if(@err_nums>0)--说明语句有错
  rollback Transaction tran_Change--回滚事务
else
  commit Transaction tran_Change

select * from Customers
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值