国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

mysql - InnoDB中的鎖

瀏覽:113日期:2022-06-20 14:41:02

問題描述

問題解答

回答1:

------- TRX HAS BEEN WAITING 28 SEC FOR THIS LOCK TO BE GRANTED:RECORD LOCKS space id 6 page no 4 n bits 80 index idx_a of table `test`.`t` trx id 637972 lock_mode X locks gap before rec insert intention waitingRecord lock, heap no 4 PHYSICAL RECORD: n_fields 2; compact format; info bits 32 0: len 4; hex 8000000b; asc ;; 1: len 6; hex 000000000414; asc ;;

這里說的很清楚啊 lock_mode X意味著是排它鎖 gap代表是區間鎖也就是說在insert之前該表加入了區間排他鎖,為什么呢?因為之前執行的這句delete from t where a = 11;會在(negative infinity,11]這個區間加上排他鎖,為什么是排他鎖而不是Record Lock呢,因為你這里的a并非唯一索引,只是一個普通的索引,具體的看http://dev.mysql.com/doc/refman/5.7/en/innodb-locking.html

回答2:

mysql默認的會話隔離級別是repeated read,會產生更多的gap鎖,如果可以接受幻讀,可以考慮降為read commit級別,減少鎖沖突的概率。

相關文章:
主站蜘蛛池模板: 南部县| 莱西市| 衡阳市| 伽师县| 红河县| 南昌县| 淄博市| 梁山县| 合肥市| 阜城县| 合肥市| SHOW| 德钦县| 卢湾区| 曲麻莱县| 同江市| 原阳县| 周口市| 富平县| 合山市| 阳江市| 和林格尔县| 武穴市| 四平市| 温泉县| 上犹县| 保亭| 内江市| 仪征市| 广宁县| 安顺市| 东乡县| 京山县| 丰顺县| 喀什市| 平武县| 安乡县| 漳浦县| 南雄市| 浦江县| 噶尔县|