MYSQL事务

常用语句
show create table 表名;  // 查看表结构,表引擎
show open tables ; // 查看表锁状态
lock table 表名 READ; // 添加读锁,阻塞所有的update操作
unlock tables 解锁
lock table 表名 WRITE ; // 添加独占写锁,阻塞其他用户的update操作,其他回话中无法读
MYSQL事务,锁表
SELECT
    trx_id AS  `事务ID`,
    trx_state AS `事务状态`,
    trx_requested_lock_id  AS  `事务需要等待的资源`,
    trx_wait_started    AS  `事务开始等待时间`,
    trx_tables_in_use AS `事务使用表`,
    trx_tables_locked AS `事务拥有锁`,
    trx_rows_locked  AS `事务锁定行`,
    trx_rows_modified  AS `事务更改行`
FROM
    information_schema.innodb_trx ;
SELECT
    lock_id         AS  `锁ID`,
    lock_trx_id    AS  `拥有锁的事务ID`,
    lock_mode      AS  `锁模式    `,
    lock_type      AS  `锁类型`,
    lock_table         AS  `被锁的表`,
    lock_index         AS  `被锁的索引`,
    lock_space         AS  `被锁的表空间号`,
    lock_page      AS  `被锁的页号`,
    lock_rec       AS  `被锁的记录号`,
    lock_data      AS  `被锁的数据`
FROM
    information_schema.innodb_locks;
SELECT
  requesting_trx_id   AS  `请求锁的事务ID`,
  requested_lock_id   AS  `请求锁的锁ID`,
  blocking_trx_id     AS  `当前拥有锁的事务ID`,
  blocking_lock_id    AS  `当前拥有锁的锁ID`
FROM
  innodb_lock_waits;
事务控制语句
begin,start transaction 显示开启一个事务
commit,commit work 提交事务
rollback rollback work 回滚数据,结束事务
save point identifier 创建一个保存点
release savepoint identifier 删除一个保存点
rollback to identifier 事务回滚到指定保存点
set transaction 设置事务隔离级别
set autocommit 自动提交默认1,如果不开启,每一个sql都会作为事务,直到输入commit
事务的隔离级别
隔离级别 描述 产生风险
READUNCOMMITTED 未提交读 另外一个事务修改了数据,但是未提交,本事务select可读到这些数据 脏读
READCOMMITTED 提交读 本事务只能读到提交后的数值,所以会出现两次读结果不一致 不可重复读
REPEATABLEREAD 可重复读 在同一个事务中,select的结果集是事务开始时间点的状态,哪怕有其他事务更改了数据 幻读
SERIALIZABLE 串行化 读操作会隐式获取共享锁,可以保证不同事务的互斥
锁类型 开销 加锁速度 死锁 冲突概率 并发
表级锁 不会出现死锁
行级锁 会出现死锁
页面锁 适中 适中 会出现死锁 一般 一般
1.myisam 只能使用表级锁,table read lock ,table write lock
2.myisam在执行查询语句之前,会自动给涉及的所有表加读锁,在执行更新操作时会自动给涉及所有表加写锁
3.读锁(共享锁),写锁 (排他锁)
读锁和写锁

1.select ... :快照读,不加锁
2.select ... in share mode: 当前读,加读锁
3.select ... for update : 当前读,加写锁

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 事务的定义 事务由单独单元的一个或多个SQL语句组成,在这个单元中,每个MySQL语句是相互依赖的。而整个单独单元...
    诸葛坚强阅读 1,113评论 0 3
  • 事务处理 事务处理是数据库中的一个大块头,涉及到数据的完整性与一致性问题,由于mysql存在多种数据存储引擎提供给...
    tanghomvee阅读 777评论 0 0
  • 前言:我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁这种方式。同时数据库又是...
    bbe9e62bc5ba阅读 780评论 0 2
  • 首先说一下ACID四大特性: 四大特性 原子性事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行...
    Cenuon_阅读 853评论 0 0
  • 今下午承蒙朋友邀约,赴灵川县潭下镇采摘桑葚,到达目的地,入眼满园春色,一片紫红,提篮入园,满心欢喜,任意采...
    翔遠阅读 713评论 4 3