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

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

mysql優化 - mysql innodb表鎖問題

瀏覽:123日期:2022-06-12 13:08:52

問題描述

經過測試之后,我發現以下情況都會導致表鎖 1.like 2.update,delete無條件的操作 3.update,delete有條件的操作但不是主鍵的操作select無論是有條件還是無條件,條件是不是主鍵或者索引,都不會鎖表,請問這是對的嗎?是不是我測試出現了問題?

問題解答

回答1:

select 可指定加各級鎖如共享鎖、排他鎖等,比如select ... FOR UPDATE。至于為什么需要鎖,舉個簡單例子,比如你有個單據繼承自上個單據,這時候你可以select加讀鎖,鎖定上個單據,來防止其他人在你提交前對上個單據進行修改,造成數據不一致。

回答2:

只要條件不包含主鍵,或者包含主鍵但不是等號或IN,都會鎖全表的,這就包括了問題中全部3種情況。

不管是鎖全表還是鎖幾行,select加讀鎖,update和delete加寫鎖,至于什么是讀鎖、寫鎖,可Google一下。至于細節,還可以看下事務隔離級別,這里就不展開了。

相關文章:
主站蜘蛛池模板: 金华市| 贵港市| 嘉鱼县| 红安县| 安平县| 巴青县| 马关县| 舟曲县| 郓城县| 安泽县| 莱芜市| 宁陕县| 哈尔滨市| 灵山县| 诏安县| 衡山县| 津市市| 灵台县| 垫江县| 绥江县| 铅山县| 奉节县| 余庆县| 平阳县| 建始县| 原平市| 平邑县| 孙吴县| 小金县| 长子县| 临沂市| 南宫市| 兰坪| 衡水市| 凌海市| 山丹县| 长葛市| 乌恰县| 奉新县| 新河县| 榆社县|