DBMNG数据库管理与应用

书籍是全世界的营养品。生活里没有书籍,就好像没有阳光;智慧里没有书籍,就好像鸟儿没有翅膀。
当前位置:首页 > MySQL > 技术手册

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操作)#UNLOCKUNLOCK TABLES;例1(READ-UNCOMMITTED操作)#会话aSTART TRANSACTION;#开始事务1selectsleep(10)fromfeedbackwhereid<5;#这里会默认加上隐式读锁。 这时我在事务2中 加了写锁,看下是否会等待。(如果不加写锁可能会出现脏读等怪像;也就是说事务2不加写锁的话可以直接进行写操作,出现脏读,那就证明一个事务中 从始至终只有一个锁闭合操作,即解释1的说法)selecttitlefromfeedbackwhereid=1;COMMIT;#提交事务#会话bSTART TRANSACTION;#开始事务2LOCK TABLES feedback WRITE;#加上写锁定, 这时会写锁等待吗?的确被锁住了,我要等待事务1解锁后,我才可以加写锁。以保证事务1能正确地读到我的更新信息,对于并发时候用这个隔离级别的话适合手动加锁来更新消息。update feedbacksettitle='609-1709'whereid=3;#写锁权,执行写操作UNLOCK TABLES;#解除写锁(注意:当当前所有的表均被锁定时,UNLOCK TABLES可以提交事务,我们不想UNLOCK TABLES提交事务,怎么办?)COMMIT;#提交事务

本站文章内容,部分来自于互联网,若侵犯了您的权益,请致邮件chuanghui423#sohu.com(请将#换为@)联系,我们会尽快核实后删除。
Copyright © 2006-2023 DBMNG.COM All Rights Reserved. Powered by DEVSOARTECH            豫ICP备11002312号-2

豫公网安备 41010502002439号