mysql-mysql13mysql事务

一丶什么是事务

​ 开启一个事务能够包含一些sql语句,这些sql语句要么同时成功
​ 要么一个都别想成功,称之为事务的原子性python

二丶事务的做用

保证了对数据操做的数据安全性mysql

案例:用交行的卡操做建行ATM机给工商的帐户转钱sql

三丶事务应该具备的4个属性(重点)

原子性、一致性、隔离性、持久性。这四个属性一般称为ACID特性数据库

  1. 原子性(atomicity)。一个事务是一个不可分割的工做单位,事务中包括的诸操做要么都作,要么都不作。
  2. 一致性(consistency)。事务必须是使数据库从一个一致性状态变到另外一个一致性状态。一致性与原子性是密切相关的。
  3. 隔离性(isolation)。一个事务的执行不能被其余事务干扰。即一个事务内部的操做及使用的数据对并发的其余事务是隔离的,并发执行的各个事务之间不能互相干扰。
  4. 持久性(durability)。持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其余操做或故障不该该对其有任何影响。

四丶事务的实现

create table user(
id int primary key auto_increment,
name char(32),
balance int
);

insert into user(name,balance)
values
('wsb',1000),
('egon',1000),
('ysb',1000);

# 修改数据以前先开启事务操做
start transaction;

# 修改操做
update user set balance=900 where name='wsb'; #买支付100元
update user set balance=1010 where name='egon'; #中介拿走10元
update user set balance=1090 where name='ysb'; #卖家拿到90元

# 回滚到上一个状态
rollback;

# 开启事务以后,只要没有执行commit操做,数据其实都没有真正刷新到硬盘
commit;
"""开启事务检测操做是否完整,不完整主动回滚到上一个状态,若是完整就应该执行commit操做"""

# 站在python代码的角度,应该实现的伪代码逻辑,
try:
    update user set balance=900 where name='wsb'; #买支付100元
    update user set balance=1010 where name='egon'; #中介拿走10元
    update user set balance=1090 where name='ysb'; #卖家拿到90元
except 异常:
    rollback;
else:
    commit;
相关文章
相关标签/搜索