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

你可能感兴趣的:(mysql管理)