Mysql --分区(4)List分区

本文详细介绍了数据库LIST分区的概念及其与RANGE分区的区别。通过具体实例展示了如何创建LIST分区表,并解释了如何通过VALUES IN指定整数值集合来定义分区。此外,还讨论了在不同存储引擎下INSERT操作的行为差异以及如何使用IGNORE关键字处理插入错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

LIST分区

LIST分区是建立离散的值列表告诉数据库特定的值属于哪个分区,LIST分区在很多方面类似于RANGE分区,区别在LIST分区是从属于一个枚举列表的值得集合,RANGE分区是从属于一个连续区间值得集合。
LIST分区通过使用PARTITION BY LIST(expr)子句来实现,expr是某列值或一个局域某列值返回一个整数值得表达式,然后通过VALUES IN(value_list)的方式来定义分区,其中value_list是一个逗号分隔的整数列表。与RANGE分区不同,LIST分区不必声明任何特定顺序

下面的例子中我们以下表为基表

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT,
    store_id INT
);

假设有20家店铺,下表中列出了各个区域包含的店铺ID

Region Store ID Numbers
North 3, 5, 6, 9, 17
East 1, 2, 10, 11, 19, 20
West 4, 12, 13, 14, 18
Central 7, 8, 15, 16

下面按照店铺所属区域进行分区

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT,
    store_id INT
)
PARTITION BY LIST(store_id) (
    PARTITION pNorth VALUES IN (3,5,6,9,17),
    PARTITION pEast VALUES IN (1,2,10,11,19,20),
    PARTITION pWest VALUES IN (4,12,13,14,18),
    PARTITION pCentral VALUES IN (7,8,15,16)
);

假设西部门店的全部出售给了另一家公司
可以使用ALTER TABLE employees TRUNCATE PARTITION pWest清空数据
当然也可使用ALTER TABLE employees DROP PARTITION pWest删除这一分区

与RANGE分区不同的是,LIST分区没有MAXVALUE这种关键字。如果要插入的数据与分区列表不匹配,会引发错误

mysql> CREATE TABLE h2 (
    ->   c1 INT,
    ->   c2 INT
    -> )
    -> PARTITION BY LIST(c1) (
    ->   PARTITION p0 VALUES IN (1, 4, 7),
    ->   PARTITION p1 VALUES IN (2, 5, 8)
    -> );
Query OK, 0 rows affected (0.11 sec)

mysql> INSERT INTO h2 VALUES (3, 5);
ERROR 1525 (HY000): Table has no partition for value 3

不过当你使用下面这种MySQL特有的插入语法时,需要注意
INSERT INTO h2 VALUES (2, 5), (6, 10), (7, 5), (3, 1), (1, 9);
如果H2表为事务引擎表,如innodb,那么整个插入被视为一个事务,所以当任何一条记录没有匹配到分区列表时,所有的记录都不被插入
如果H2表为非事务引擎表,如MyISAM,那么引发错误前的记录将被插入,而引发错误的记录包括其后的记录都会插入失败

CREATE TABLE h2 (
  c1 INT,
  c2 INT
) engine=innodb
PARTITION BY LIST(c1) (
  PARTITION p0 VALUES IN (1, 4, 7),
  PARTITION p1 VALUES IN (2, 5, 8)
);

mysql> insert into h2 values(1,2),(4,8),(7,8),(3,4),(1,8);
ERROR 1526 (HY000): Table has no partition for value 3
mysql> select * from h2;
Empty set (0.00 sec)

CREATE TABLE h2 (
  c1 INT,
  c2 INT
) engine=myisam
PARTITION BY LIST(c1) (
  PARTITION p0 VALUES IN (1, 4, 7),
  PARTITION p1 VALUES IN (2, 5, 8)
);

mysql> insert into h2 values(1,2),(4,8),(7,8),(3,4),(1,8);
ERROR 1526 (HY000): Table has no partition for value 3
mysql> select * from h2;
+------+------+
| c1   | c2   |
+------+------+
|    1 |    2 |
|    4 |    8 |
|    7 |    8 |
+------+------+
3 rows in set (0.00 sec)

你可使用IGNORE关键字避免上面的情况,使用IGNORE关键字后,只有引发错误的值将不被插入,其他正常值可以插入,并且不会抛出错误

创建innodb表
drop table if exists h2;
CREATE TABLE h2 (
  c1 INT,
  c2 INT
) engine=innodb
PARTITION BY LIST(c1) (
  PARTITION p0 VALUES IN (1, 4, 7),
  PARTITION p1 VALUES IN (2, 5, 8)
);

mysql> insert IGNORE into h2 values(1,2),(4,8),(7,8),(3,4),(1,8);
Query OK, 4 rows affected (0.00 sec)
Records: 5  Duplicates: 1  Warnings: 0

mysql> select * from h2;
+------+------+
| c1   | c2   |
+------+------+
|    1 |    2 |
|    4 |    8 |
|    7 |    8 |
|    1 |    8 |
+------+------+
4 rows in set (0.00 sec)
注意在未使用IGNORE前,所有的记录都没有被插入

创建MyISAM表
drop table if exists h2;
CREATE TABLE h2 (
  c1 INT,
  c2 INT
) engine=myisam
PARTITION BY LIST(c1) (
  PARTITION p0 VALUES IN (1, 4, 7),
  PARTITION p1 VALUES IN (2, 5, 8)
);

mysql> insert IGNORE into h2 values(1,2),(4,8),(7,8),(3,4),(1,8);
Query OK, 4 rows affected (0.00 sec)
Records: 5  Duplicates: 1  Warnings: 0

mysql> select * from h2;
+------+------+
| c1   | c2   |
+------+------+
|    1 |    2 |
|    4 |    8 |
|    7 |    8 |
|    1 |    8 |
+------+------+
4 rows in set (0.00 sec)
注意未使用IGNORE前,最后一条(1,8)也没有被插入
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值