MYSQL事务与锁,需要手动加锁吗?

锁分为:隐式锁、显式锁。共享锁、排它锁。表锁、行锁、页级锁。
这些锁一般都是自动加锁。不用去管它,只需要知道在什么时候MYSQL会去加锁就行。
是否可以手动加锁?
可以。

事务中的锁 和 非事务中的锁

非事务中的锁,普通锁
手动加锁分为:悲观锁和乐观锁。估计是傻B式的加锁(结果是: 从操作员读出数据、开始修改直至提交修改结果的全过程,甚至还包括操作 员中途去煮咖啡的时间,可能忘记解锁)
自动加锁:一般MYSQL在执行CREATE,ALTER,INSERT等命令时会自动加锁

事务中的锁
事务的四个隔离级别 ,对应不同的锁机制:
隔离级别:Read Uncommitted(读取未提交内容)、Read Committed(读取提交内容)、Repeatable Read(可重读)、Serializable(可串行化) 

Repeatable Read和 Serializable 2个 事务隔离 级别 不需要手动加锁的,我认为在这2个事务级别中加锁是没有意义的,因为其他会话的事务是无法取得这2种事务中执行的数据的。 Repeatable Read和 Serializable )获取的永远是原始数据。

Read Uncommitted、Read Committed 2个事务隔离级别可以手动加锁 ,因为这2种级别可能出现(脏读、不可重复读之类的“假数据”),所以在必要的时候进行手动加锁是不错的选择,我暂时是这样理解的。
 
    

解析1:默认事务中 从始至终只有一个锁闭合操作,即
LOCK TABLES tab;
#LOCK
#在此中间的 所有SQL语句都不会加锁和解锁,需要手动加锁的话见例1(READ-UNCOMMITTED操作)
#UNLOCK
UNLOCK TABLES;



例1(READ-UNCOMMITTED操作)
#会话a
START TRANSACTION; #开始事务1

select sleep(10) from feedback where id < 5;
#这里会默认加上隐式读锁。 这时我在事务2中 加了写锁,看下是否会等待。(如果不加写锁可能会出现脏读等怪像;也就是说事务2不加写锁的话可以直接进行写操作,出现脏读,那就证明一个事务中 从始至终只有一个锁闭合操作,即解释1的说法)

select title from feedback where id = 1;
COMMIT; #提交事务

#会话b
START TRANSACTION; #开始事务2

LOCK TABLES feedback WRITE;
#加上写锁定, 这时会写锁等待吗?的确被锁住了,我要等待事务1解锁后,我才可以加写锁。以保证事务1能正确地读到我的更新信息,对于并发时候用这个隔离级别的话适合手动加锁来更新消息。
update feedback set title='609-1709' where id=3;#写锁权,执行写操作

UNLOCK TABLES; #解除写锁(注意:当当前所有的表均被锁定时,UNLOCK TABLES可以提交事务,我们不想UNLOCK TABLES提交事务,怎么办?

COMMIT; #提交事务







你可能感兴趣的:(mysql)