mysql管理

mysql的锁:mysql

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

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

  表锁:优化

  行锁:对象

  锁的实现位置: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;锁在执行完后就自动释放。但其余的存储引擎都是自动添加锁。it

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

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

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

  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,每一个事务启动时,都会为当前建立一个快照,全部操做都在当前快照中操做。只在读已提交和可重读下有效。

相关文章
相关标签/搜索