上次我們介紹了:MySQL 5.5 分區之多列分區詳解,本文我們介紹一下MySQL 5.5 分區之非整數列分區的知識,接下來我們就一起來了解一下這部分內容吧!
非整數列分區
任何使用過分區的人應該都遇到過不少問題,特別是面對非整數列分區時,MySQL 5.1只能處理整數列分區,如果你想在日期或字符串列上進行分區,你不得不使用函數對其進行轉換。
MySQL 5.5中新增了兩類分區方法,RANG和LIST分區法,同時在新的函數中增加了一個COLUMNS關鍵詞。我們假設有這樣一個表:
- CREATE TABLE expenses (
- expense_date DATE NOT NULL,
- category VARCHAR(30),
- amount DECIMAL (10,3)
- );
如果你想使用MySQL 5.1中的分區類型,那你必須將類型轉換成整數,需要使用一個額外的查找表,到了MySQL 5.5中,你可以不用再進行類型轉換了,如:
- ALTER TABLE expenses
- PARTITION BY LIST COLUMNS (category)
- (
- PARTITION p01 VALUES IN ( 'lodging', 'food'),
- PARTITION p02 VALUES IN ( 'flights', 'ground transportation'),
- PARTITION p03 VALUES IN ( 'leisure', 'customer entertainment'),
- PARTITION p04 VALUES IN ( 'communications'),
- PARTITION p05 VALUES IN ( 'fees')
- );
這樣的分區語句除了更加易讀外,對數據的組織和管理也非常清晰,上面的例子只對category列進行分區。
在MySQL 5.1中使用分區另一個讓人頭痛的問題是date類型即日期列),你不能直接使用它們,必須使用YEAR或TO_DAYS轉換這些列,如:
- /* 在MySQL 5.1中*/
- CREATE TABLE t2
- (
- dt DATE
- )
- PARTITION BY RANGE (TO_DAYS(dt))
- (
- PARTITION p01 VALUES LESS THAN (TO_DAYS('2007-01-01')),
- PARTITION p02 VALUES LESS THAN (TO_DAYS('2008-01-01')),
- PARTITION p03 VALUES LESS THAN (TO_DAYS('2009-01-01')),
- PARTITION p04 VALUES LESS THAN (MAXVALUE));
- SHOW CREATE TABLE t2 \G
- *************************** 1. row ***************************
- Table: t2
- Create Table: CREATE TABLE `t2` (
- `dt` date DEFAULT NULL
- ) ENGINE=MyISAM DEFAULT CHARSET=latin1
- /*!50100 PARTITION BY RANGE (TO_DAYS(dt))
- (PARTITION p01 VALUES LESS THAN (733042) ENGINE = MyISAM,
- PARTITION p02 VALUES LESS THAN (733407) ENGINE = MyISAM,
- PARTITION p03 VALUES LESS THAN (733773) ENGINE = MyISAM,
- PARTITION p04 VALUES LESS THAN MAXVALUE ENGINE = MyISAM) */
看上去非常糟糕,當然也有變通辦法,但麻煩確實不少。使用YEAR或TO_DAYS定義一個分區的確讓人費解,查詢時不得不使用赤裸列,因為加了函數的查詢不能識別分區。
但在MySQL 5.5中情況發生了很大的變化,現在在日期列上可以直接分區,並且方法也很簡單。
- /*在MySQL 5.5中*/
- CREATE TABLE t2
- (
- dt DATE
- )
- PARTITION BY RANGE COLUMNS (dt)
- (
- PARTITION p01 VALUES LESS THAN ('2007-01-01'),
- PARTITION p02 VALUES LESS THAN ('2008-01-01'),
- PARTITION p03 VALUES LESS THAN ('2009-01-01'),
- PARTITION p04 VALUES LESS THAN (MAXVALUE));
- SHOW CREATE TABLE t2 \G
- *************************** 1. row ***************************
- Table: t2
- Create Table: CREATE TABLE `t2` (
- `dt` date DEFAULT NULL
- ) ENGINE=MyISAM DEFAULT CHARSET=latin1
- /*!50500 PARTITION BY RANGE COLUMNS(dt)
- (PARTITION p01 VALUES LESS THAN ('2007-01-01') ENGINE = MyISAM,
- PARTITION p02 VALUES LESS THAN ('2008-01-01') ENGINE = MyISAM,
- PARTITION p03 VALUES LESS THAN ('2009-01-01') ENGINE = MyISAM,
- PARTITION p04 VALUES LESS THAN (MAXVALUE) ENGINE = MyISAM) */
在這裡,通過函數定義和通過列查詢之間沒有沖突,因為是按列定義的,我們在定義中插入的值是保留的。
關於MySQL 5.5 分區之非整數列分區的知識就介紹到這裡了,希望本次的介紹能夠對您有所收獲!
原文出處:http://lujia35.iteye.com/blog/718899。