""
潛在場景如何?
當MySQL單表的數據量過大時,數據庫的訪問速度會下降,“數據量大”問題的常見解決方案是“水平切分”。
MySQL常見的水平切分方案有哪些?
(1)分庫分表;
(2)分區表。
畫外音:我C,沒聽過分區表,有朋友驚歎。
什麼是分庫分表?
把一個很大的庫(表)的數據分到幾個庫(表)中,每個庫(表)的結構都相同,但他們可以分佈在不同的MySQL實例,甚至不同的物理機器上,以達到降低單庫(表)數據量,提高讀寫性能的目的。
分庫分表有什麼缺點?
分庫分表往往是業務層實施的,分庫分表後,往往需要升級系統:
(1)修改某些SQL代碼;
(2)喪失某些SQL功能。
什麼是分區表?
所有數據,邏輯上還在一個表中,但物理上,可以根據一定的規則放在不同的文件中。這是MySQL5.1之後支持的功能,業務代碼無需改動。
分區表看上去很帥氣,為什麼大部分互聯網公司不使用,而更多的選擇分庫分表來進行水平切分呢?
分區表的一些缺點,是大數據量,高併發量的業務難以接受的:
(1)如果SQL不走分區鍵,很容易出現全表鎖;
(2)在分區表實施關聯查詢,就是一個災難;
(3)分庫分表,自己掌控業務場景與訪問模式,可控;分區表,工程師寫了一個SQL,自己無法確定MySQL是怎麼玩的,不可控;
畫外音:類似於,不要把業務邏輯實現在存儲過程,用戶自定義函數,觸發器裡,而要實現在業務代碼裡一樣。
(4)DBA給OP埋坑,容易大打出手,造成同事矛盾;
(5)…
當然,在數據量和併發量不太大,或者按照時間來存儲冷熱數據或歸檔數據的一些特定場景下,分區表還是有上場機會的。
畫外音:例如,按照時間分區,存儲日誌。
希望這一分鐘有收穫。
相關推薦
'“純淨蒼穹”被官方成功打撈?一分鐘詳解射手為啥進入最好的時代'
"大家好,這裡是沐木遊戲君。相信朋友們最近應該聽說了不少關於王者榮耀2.0+版本的消息,這次的改動之大讓廣大玩家們寢食難安,不知道這次改動具體會帶給我們每個玩傢什麼樣的變化。本期沐木主要來為大家詳解一下“純淨蒼穹”這件一直處於二線的半冷門裝備,將會在新的2.0+版本中如何帶...
'45067元加班費為啥不得不給呢?考勤表沒員工簽字,公章管理不力'
"周某於2017年2月6日入職北京某工程公司, 2018年10月30日合同到期終止。其後,周某申請就經濟補償,加班費申請仲裁,獲得了仲裁支持。公司就考勤、加班費提出了異議,並申請上訴。一審法院庭審中,雙方對於周某是否存在加班存在爭議。周某提交《公司員工考勤表》證明其加班的事...
'漫畫丨文件為啥不用大白話寫,非要拐彎抹角增加理解難度?'
"無視上意,追悔莫及任何聲音和消息的發出都不是無緣由的,若不加判斷直接忽略,就會錯過一些重要的東西不要誤會,我不是針對某些人,而是針對所有人!下級不能忽略上級的意圖,就像上級不能忽視下級的吐槽一樣不要覺得沒有硬性要求的、不涉及福利待遇的,泛形式化的東西就與你無關哪怕只是一個...
'特朗普週末表示不願與華為公司做生意 外交部迴應'
"2019年8月19日,外交部發言人耿爽主持例行記者會。問:美國總統特朗普週末表示不願與華為公司做生意,他還沒準備好與中國達成貿易協議。在這種情況下,中方是否認為還有繼續磋商的意義?答:關於華為問題,我們多次說過,中美企業之間的經貿合作是互利共贏的。中美元首大阪會晤時,美方...
推薦中...