MySQL 锁
MySQL中最常见的锁有全局锁、表锁、行锁。
全局锁
全局锁用于锁住当前库中的所有实例,也就是说会将所有的表都锁住。一般用于做数据库备份的时候就需要添加全局锁,数据库备份的时候是一个表一个表备份,如果没有加锁的话在备份的时候会有其他的事务进行提交,从而造成数据不一致,加锁后能保证在备份的时候不会有其他事务提交数据。
如何添加一个全局锁呢?
通过以下命令添加一个全局锁
#设置全局锁 flush tables with read lock;
执行增删改操作,会发现当前锁冲突,无法操作
insert into user (username, password, phone) values ('Jack', '$2a$10$6ptTq3V9XfaJmFYwYT2W9ud377BUkEWk.whf.iQ.0sX5F.L497rAC', '12345678901');
执行读取操作
#读取user select * from user;
可以发现,添加全局锁后,整个数据库都变成了只读状态,操作完别忘记释放全局锁。
#释放全局锁 unlock tables;