我們大家都知道通過MySQL數據庫分區Partition)可以提升MySQL數據庫的性能,那麼到底什麼是MySQL數據庫分區呢?以及其實際應用的好處的表現有哪些呢?以下的文章就是對這些內容的描述。
什麼是數據庫分區?
數據庫分區是一種物理數據庫設計技術,DBA和數據庫建模人員對其相當熟悉。雖然分區技術可以實現很多效果,但其主要目的是為了在特定的SQL操作中減少數據讀寫的總量以縮減響應時間。 分區主要有兩種形式://這裡一定要注意行和列的概念row是行,column是列)
水平分區Horizontal Partitioning) 這種形式分區是對表的行進行分區,通過這樣的方式不同分組裡面的物理列分割的數據集得以組合,從而進行個體分割單分區)或集體分割1個或多個分區)。所有在表中定義的列在每個數據集中都能找到,所以表的特性依然得以保持。
舉個簡單例子:一個包含十年發票記錄的表可以被MySQL數據庫分區為十個不同的分區,每個分區包含的是其中一年的記錄。朋奕注:這裡具體使用的分區方式我們後面再說,可以先說一點,一定要通過某個屬性列來分割,譬如這裡使用的列就是年份)
垂直分區Vertical Partitioning) 這種分區方式一般來說是通過對表的垂直劃分來減少目標表的寬度,使某些特定的列被劃分到特定的分區,每個分區都包含了其中的列所對應的行。
舉個簡單例子:一個包含了大text和BLOB列的表,這些text和BLOB列又不經常被訪問,這時候就要把這些不經常使用的text和BLOB了劃分到另一個分區,在保證它們數據相關性的同時還能提高訪問速度。
在數據庫供應商開始在他們的數據庫引擎中建立分區主要是水平分區)時,DBA和建模者必須設計好表的物理分區結構,不要保存冗余的數據不同表中同時都包含父表中的數據)或相互聯結成一個邏輯父對象通常是視圖)。這種做法會使水平分區的大部分功能失效,有時候也會對垂直分區產生影響。
在MySQL 5.1中進行分區
MySQL5.1中最激動人心的新特性應該就是對水平MySQL數據庫分區的支持了。這對MySQL的使用者來說確實是個好消息,而且她已經支持分區大部分模式:
Range范圍) – 這種模式允許DBA將數據劃分不同范圍。例如DBA可以將一個表通過年份劃分成三個分區,80年代1980's)的數據,90年代1990's)的數據以及任何在2000年包括2000年)後的數據。
Hash哈希) – 這中模式允許DBA通過對表的一個或多個列的Hash Key進行計算,最後通過這個Hash碼不同數值對應的數據區域進行分區,。例如DBA可以建立一個對表主鍵進行分區的表。
Key鍵值) – 上面Hash模式的一種延伸,這裡的Hash Key是MySQL系統產生的。
List預定義列表) – 這種模式允許系統通過DBA定義的列表的值所對應的行數據進行分割。例如:DBA建立了一個橫跨三個分區的表,分別根據2004年2005年和2006年值所對應的數據。
Composite復合模式) - 很神秘吧,哈哈,其實是以上模式的組合使用而已,就不解釋了。舉例:在初始化已經進行了Range范圍分區的表上,我們可以對其中一個分區再進行hash哈希分區。