场景
【项目踩坑】Mysql分区:分区键和唯一索引主键的关系,解决报错 A PRIMARY KEY must include all columns in the table’s partitioning
今天在建立mysql 分区表,设置主键与索引时候报错
错误:
ERROR 1503 (HY000): A PRIMARY KEY must include all columns in the table’s partitioning
ERROR 1503 (HY000): A UNIQUE INDEX must include all columns in the table’s partitioning function
结论
主键必须包括表的分区函数中的所有列,一个惟一的索引必须包括表的分区函数中的所有列,是不是不太好理解意思?分区的key必须是 主键!
那就来看看分析
分析1
其实就是这么个意思:表上的每一个唯一性索引必须用于分区表的表达式上(其中包括主键索引)
下面我来举几个例子:
SQL
CREATE TABLE t1 (
id INT NOT NULL,
aid DATE NOT NULL,
bid INT NOT NULL,
PRIMARY KEY (id)
)
PARTITION BY KEY(bid)
PARTITIONS 10;
[Err] 1503 - A PRIMARY KEY must include all columns in the table’s partitioning function
SQL
CREATE TABLE t1 (