查看: 1730|回复: 0

[Mysql数据库] Mysql 分区介绍(五) —— LIST COLUMNS分区

发表于 2018-4-4 08:00:02

Mysql 5.6开始支持LIST COLUMNS分区, 可以开始使用多个列作为分区的键, 并且列的数据类型除了数字类型可以作为分区列; 你也可以使用字符串类型, DATE和DATETIME

你有一个在12个城市客户的业务, 为了销售和市场的目的, 你的组织每3个城市划分为一个区域
针对LIST COLUMNS分区, 你可以基于城市的名称创建一个客户数据表并声明4个分区当你的客户存在对应的这个区域:

  1. CREATE TABLE customers_1 (
  2. first_name VARCHAR(25),
  3. last_name VARCHAR(25),
  4. street_1 VARCHAR(30),
  5. street_2 VARCHAR(30),
  6. city VARCHAR(15),
  7. renewal DATE
  8. )
  9. PARTITION BY LIST COLUMNS(city) (
  10. PARTITION pRegion_1 VALUES IN('Oskarshamn', 'H?gsby', 'M?nster?s'),
  11. PARTITION pRegion_2 VALUES IN('Vimmerby', 'Hultsfred', 'V?stervik'),
  12. PARTITION pRegion_3 VALUES IN('N?ssj?', 'Eksj?', 'Vetlanda'),
  13. PARTITION pRegion_4 VALUES IN('Uppvidinge', 'Alvesta', 'V?xjo')
  14. );
复制代码

使用日期分区

  1. CREATE TABLE customers_2 (
  2. first_name VARCHAR(25),
  3. last_name VARCHAR(25),
  4. street_1 VARCHAR(30),
  5. street_2 VARCHAR(30),
  6. city VARCHAR(15),
  7. renewal DATE
  8. )
  9. PARTITION BY LIST COLUMNS(renewal) (
  10. PARTITION pWeek_1 VALUES IN('2010-02-01', '2010-02-02', '2010-02-03',
  11. '2010-02-04', '2010-02-05', '2010-02-06', '2010-02-07'),
  12. PARTITION pWeek_2 VALUES IN('2010-02-08', '2010-02-09', '2010-02-10',
  13. '2010-02-11', '2010-02-12', '2010-02-13', '2010-02-14'),
  14. PARTITION pWeek_3 VALUES IN('2010-02-15', '2010-02-16', '2010-02-17',
  15. '2010-02-18', '2010-02-19', '2010-02-20', '2010-02-21'),
  16. PARTITION pWeek_4 VALUES IN('2010-02-22', '2010-02-23', '2010-02-24',
  17. '2010-02-25', '2010-02-26', '2010-02-27', '2010-02-28')
  18. );
复制代码

但是这种情况在日期增长到非常大的时候是很复杂的, 所以这种还是使用RANGE 分区方式比较好。



回复

使用道具 举报