mysql事务(开启,回滚,提交,四大特征以及隔离级别)

--     2.事务
--        1)事务的基本介绍
--           1.一个包含多个步骤的业务被事务管理,那么这些操作要么同时成功要么同时失败;
--           2.开启事务: start transaction;
--           3.回滚: rollback
--           4.提交: commit
-- 添加数据
INSERT INTO account (NAME,balance)VALUES ('zhangyu',10000),('lianai',1000);

SELECT * FROM account;
--  1.开启事务
START TRANSACTION;
-- 张余给恋爱转5000;
UPDATE account SET balance = balance - 5000 WHERE NAME ='zhangyu';
-- 恋爱账户多5000
UPDATE account SET balance = balance +5000 WHERE NAME = 'lianai';
--  2.回滚事务(在哪开就回滚这个状态之前)
ROLLBACK;
-- 发现没有问题就可以提交了;
COMMIT;
-- mysql事务自动提交

--        2)事务的四大特征
--                 1.原子性:不可分割的最小的单位,同时成功/失败
--                 2.持久性:事务一旦提交或者回滚,数据会持久化保存数据
--                 3.隔离性:多个事之间,相互独立:
--                 4.一致性:事务操作前后数据总量不变
--        3)事务的隔离级别(了解)
--                    多个事务之间相互独立,多个事务操作同一批数据会出现问题,设置不同级别可以解决;
-- 存在问题:1.脏读:一个事务独缺到另一个事务没有提交的数据
--                   2.不可重复读:同一个事务中,两次读到的数据不一样    

--      隔离级别(安全性越来越高,效率越来越低)

--   read unicomMitted:产生脏读,不可重复读,幻读
--   read committed 产生不可重复读,幻读
--   repeatable read 产生幻读(mysql默认)
--   serializable:串行化  可以解决所有问题

-- 查询隔离级别
-- select @@tx_isolation;
-- 设置隔离级别
-- set global transactioin isolation level 级别字符串;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值