zoukankan      html  css  js  c++  java
  • MySQL之事务

    MySQL事务:
    1.MySQL事务控制语句
    (1).开启事务
    begin;
    (2).提交事务
    commit;
    (3).回滚事务
    rollback;
    (4).设置事务是否自动提交
    set autocommit = {0 | 1}; // 0不自动提交,1自动提交
    例如:
    begin;// 开启事务
    insert into table_name values(内容);
    commit;// 提交事务
    这个就是一个简单的插入数据的事务
    begin;// 开启事务
    insert into table_name values(内容);// 后悔了,不想插入数据了
    rollback;// 回滚,取消这次的事务操作
    这个就是一个简单的插入数据的回滚事务
    2.MySQL事务隔离语句
    查看MySQL的隔离级别
    show variables like 'tx_isolation';
    (1).read-uncommitted(读取未提交内容)
    脏读(带来的问题);
    一个用户在两次查询结果中的内容不相同.
    设置默认隔离级别(设置完成后需要重新登录):
    set global transaction isolation level read uncommitted;
    两个用户同时登录数据库,分别开启事务,一个用户的事务执行增删改操作,另一个用户的事务只进行查询操作,前者执行完操作,不进行提交,后者就可以看到操作结果,但如果这时候前者进行了事务的回滚,后者这时候查询就会看到不一样与上次不一样的结果(也就是没有进行操作的结果),这就是脏读问题.
    (2).read committed(读取提交内容)
    事务只能看见已经提交事务所做的改变,同一查询可能返回不同的结果,此级别导致的不可重复读问题.
    设置默认隔离级别(设置完成后需要重新登录):
    set global transaction isolation level read committed;
    在一次事务中,看到了两次不一样的查询结果(与脏读类似).
    (3).repeatable read(可重复读)
    能确保同一事务的多个实例在并发读取数据时,会看到同样的数据行(数据库的莫尔纳隔离级别).
    设置默认隔离级别(设置完成后需要重新登录):
    set global transaction isolation level repeatable read;
    也就在在一次事务中,无论另一个用户如何修改数据,在这次事务中查询到的结果总是相同.
    ***隐式事务提交***:
    alter table users engine = innodb;// 会造成事务的隐式提交
     
    3.InnoDB锁机制
    (1).一个表中没有任何的主键和索引,一个事务会锁住这个表的所有记录,其他的事务无法进行操作这个表.
    (2).一个表中存在主键或者索引,一个事务会锁住表的他操作的某行数据,不回锁住整个表,如果其他的事务操作这个表的其他数据,这个时候是不受影响的.需要注意的是这的行级锁是间隙锁,也就是说如果你修改的某几行数据,比如过修改id<10的n行数据.=,这时,id = 11的数据也会被锁住,这是需要注意的.
     
     
  • 相关阅读:
    servlet上传图片 服务器路径(转)
    图片和提交servlet的相对和绝对路径
    Intel 的面试经历中国研究院
    CentOS-6.5-x86_64 最小化安装,已安装包的总数,这些包?
    西门子PLC学习笔记8-(计时器)
    这个周末我太累了
    windows7股票的,win8残疾人,安装Han澳大利亚sinoxn个时间,sinox它支持大多数windows软体
    net.sf.json 迄今 时刻 格式 办法
    ar命令提取.a时刻,一个错误 is a fat file (use libtool(1) or lipo(1) and ar(1) on it)
    POJ 2187: Beauty Contest(旋转卡)
  • 原文地址:https://www.cnblogs.com/wadmwz/p/7501337.html
Copyright © 2011-2022 走看看