日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 單片機 > 小林coding
[導讀]大家好,我是小林。昨晚在群劃水的時候,看到有位讀者說了這么一件事。大概就是,在線上執(zhí)行一條update語句修改數(shù)據(jù)庫數(shù)據(jù)的時候,where條件沒有帶上索引,導致業(yè)務直接崩了,被老板教訓了一波這次我們就來看看:為什么會發(fā)生這種的事故?又該如何避免這種事故的發(fā)生?說個前提,接下來說的...

大家好,我是小林。

昨晚在群劃水的時候,看到有位讀者說了這么一件事。

大概就是,在線上執(zhí)行一條 update 語句修改數(shù)據(jù)庫數(shù)據(jù)的時候,where 條件沒有帶上索引,導致業(yè)務直接崩了,被老板教訓了一波這次我們就來看看:
  • 為什么會發(fā)生這種的事故?

  • 又該如何避免這種事故的發(fā)生?

說個前提,接下來說的案例都是基于 InnoDB 存儲引擎,且事務的隔離級別是可重復讀。1?為什么會發(fā)生這種的事故?InnoDB 存儲引擎的默認事務隔離級別是「可重復讀」,但是在這個隔離級別下,在多個事務并發(fā)的時候,會出現(xiàn)幻讀的問題,所謂的幻讀是指在同一事務下,連續(xù)執(zhí)行兩次同樣的查詢語句,第二次的查詢語句可能會返回之前不存在的行。因此 InnoDB 存儲引擎自己實現(xiàn)了行鎖,通過 next-key 鎖(記錄鎖和間隙鎖的組合)來鎖住記錄本身和記錄之間的“間隙”,防止其他事務在這個記錄之間插入新的記錄,從而避免了幻讀現(xiàn)象。當我們執(zhí)行 update 語句時,實際上是會對記錄加獨占鎖(X 鎖)的,如果其他事務對持有獨占鎖的記錄進行修改時是會被阻塞的。另外,這個鎖并不是執(zhí)行完 update 語句就會釋放的,而是會等事務結束時才會釋放。在 InnoDB 事務中,對記錄加鎖帶基本單位是 next-key 鎖,但是會因為一些條件會退化成間隙鎖,或者記錄鎖。加鎖的位置準確的說,鎖是加在索引上的而非行上。比如,在 update 語句的 where 條件使用了唯一索引,那么 next-key 鎖會退化成記錄鎖,也就是只會給一行記錄加鎖。這里舉個例子,這里有一張數(shù)據(jù)庫表,其中 id 為主鍵索引。
假設有兩個事務的執(zhí)行順序如下:可以看到,事務 A 的 update 語句中 where 是等值查詢,并且 id 是唯一索引,所以只會對 id = 1 這條記錄加鎖,因此,事務 B 的更新操作并不會阻塞。
但是,在 update 語句的 where 條件沒有使用索引,就會全表掃描,于是就會對所有記錄加上 next-key 鎖(記錄鎖 間隙鎖),相當于把整個表鎖住了。假設有兩個事務的執(zhí)行順序如下:
可以看到,這次事務 B 的 update 語句被阻塞了。這是因為事務 A的 update 語句中 where 條件沒有索引列,所有記錄都會被加鎖,也就是這條 update 語句產生了 4 個記錄鎖和 5 個間隙鎖,相當于鎖住了全表。
因此,當在數(shù)據(jù)量非常大的數(shù)據(jù)庫表執(zhí)行 update 語句時,如果沒有使用索引,就會給全表的加上 next-key 鎖, 那么鎖就會持續(xù)很長一段時間,直到事務結束。而這期間除了?select ... from語句,其他語句都會被鎖住不能執(zhí)行,業(yè)務會因此停滯,接下來等著你的,就是老板的挨罵。那 update 語句的 where 帶上索引就能避免全表記錄加鎖了嗎?并不是。關鍵還得看這條語句在執(zhí)行過程中,優(yōu)化器最終選擇的是索引掃描,還是全表掃描,如果走了全表掃描,就會對全表的記錄加鎖了。2?又該如何避免這種事故的發(fā)生?我們可以將 MySQL 里的?sql_safe_updates?參數(shù)設置為 1,開啟安全更新模式。
官方的解釋:
If set to 1, MySQL aborts UPDATE or DELETE statements that do not use a key in the WHERE clause or a LIMIT clause. (Specifically, UPDATE statements must have a WHERE clause that uses a key or a LIMIT clause, or both. DELETE statements must have both.) This makes it possible to catch UPDATE or DELETE statements where keys are not used properly and that would probably change or delete a large number of rows. The default value is 0.
大致的意思是,當 sql_safe_updates 設置為 1 時。update 語句必須滿足如下條件之一才能執(zhí)行成功:
  • 使用 where,并且 where 條件中必須有索引列;

  • 使用 limit;

  • 同時使用 where 和 limit,此時 where 條件中可以沒有索引列;

delete 語句必須滿足如下條件之一才能執(zhí)行成功:
  • 使用 where,并且 where 條件中必須有索引列;

  • 同時使用 where 和 limit,此時 where 條件中可以沒有索引列;

如果 where 條件帶上了索引列,但是優(yōu)化器最終掃描選擇的是全表,而不是索引的話,我們可以使用?force index([index_name])?可以告訴優(yōu)化器使用哪個索引,以此避免有幾率鎖全表帶來的隱患。3?總結不要小看一條 update 語句,在生產機上使用不當可能會導致業(yè)務停滯,甚至崩潰。當我們要執(zhí)行 update 語句的時候,確保 where 條件中帶上了索引列,并且在測試機確認該語句是否走的是索引掃描,防止因為掃描全表,而對表中的所有記錄加上鎖。我們可以打開 MySQL 里的 sql_safe_updates 參數(shù),這樣可以預防 update 操作時 where 條件沒有帶上索引列。如果發(fā)現(xiàn)即使在 where 條件中帶上了列索引列,優(yōu)化器走的還是全標掃描,這時我們就要使用?force index([index_name])?可以告訴優(yōu)化器使用哪個索引。這次就說到這啦,下次要小心點,別再被老板挨罵啦。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉