zoukankan      html  css  js  c++  java
  • mysql管理

    mysql的锁:

      读锁:共享锁。添加锁后对读没有影响,但是对写会阻塞。

      写锁:独占锁。添加锁后对读写均会阻塞。

      表锁:

      行锁:

      锁的实现位置:mysql服务层(sql语句的解析、优化):手动添加lock table table_name lock_type;其中lock_type为read和write。unlock。

             存储引擎层:InnoDB也支持手动添加锁,且锁为行级别的锁。select * from table1 where .. lock in share mode;和select * from table1 where .. lock for update;锁在执行完后就自动释放。但其他的存储引擎都是自动添加锁。

    事务:事务只针对查询语句而言。就是ACID。

      A:原子性,在一个事务中不能作多个操作。

      C:一致性,事务前后的客观事实不会发生改变。

      I:隔离性,是指在事务提交之前所有的修改对其他人是不可见的。

      D:持久性,事务一旦提交,就是永久有效。

      mysql启动事务:start transaction,rollback,commit,savepoint indentifiy。myISAM不支持事务。对于InnoDB如果不手动开启事务,对于每一条语句都是自动提交事务。用show global variables like 'autocommit';查看是否为自动自动提交,用set global autocommit=off;

    隔离级别:读未提交读已提交、可重读、串行执行。例子:一张银行卡,你和你对象一起用。

      查看隔离级别用show global variables like '%tx_isolation%';

    MVCC:多版本并发控制。对InnoDB,每个事务启动时,都会为当前创建一个快照,所有操作都在当前快照中操作。只在读已提交和可重读下有效。

  • 相关阅读:
    python 3字符编码
    python 数据类型 datatype
    部署python django程序
    linux centos7安装python3
    关于mysql数据库优化
    关于bottle WEB框架中签名cookie的一点理解
    1111
    bottle框架剖析
    the difference __str__ and __repr__
    property getitem setitem
  • 原文地址:https://www.cnblogs.com/Jc-zhu/p/4723878.html
Copyright © 2011-2022 走看看