美文网首页
MYSQL事务

MYSQL事务

作者: 充满智慧的白痴 | 来源:发表于2020-01-21 15:22 被阅读0次
常用语句
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 : 当前读,加写锁

相关文章

网友评论

      本文标题:MYSQL事务

      本文链接:https://www.haomeiwen.com/subject/icgnoctx.html