文档解释
Error number: MY-013240; Symbol: ER_SHARED_TABLESPACE_USED_BY_PARTITIONED_TABLE; SQLSTATE: HY000
Message: Partitioned table ‘%s’ is not allowed to use shared tablespace ‘%s’. Please move all partitions to file-per-table tablespaces before upgrade.
这是MySQL数据库中出现的一个错误,ER_SHARED_TABLESPACE_USED_BY_PARTITIONED_TABLE(错误号My-013240,SQLSTATE HY000)。这个错误表明更改分区表使用的共享表空间时,出现问题。
错误说明
此错误为 MySQL 的一个实现缺陷,表明分区表使用的共享表空间发生变更时,MySQL 无法正确处理。因此,当试图更改分区表的共享表空间时,MySQL 将报出此错误。此外,只有当使用了共享表空间,而且某分区表(partitioned table)使用该共享表空间时,才会报告此错误。
常见案例
一个常见的案例是,当试图使用 ALTER TABLE…PARTITION BY 来更改分区表依赖的共享表空间时,可能会收到此错误。其他情形包括,当使用 CREATE TABLE…PARTITION BY 时也会出现这个错误,例如在对一个已经存在的表添加分区时。
解决方法
MySQL Server 允许一个分区表使用多个共享表空间,但不允许使用多个共享表空间中的同一个表空间。因此,要解决此问题,可以使用多个共享表空间以替代原有的共享表空间,让每个分区表使用不同的共享表空间。
如果使用多个共享表空间对DB进行分区,将会涉及到更多管理和运维的问题,比如在备份和恢复时,确保多个共享表空间中的数据文件一起进行备份恢复,从而保证数据的完整性。
另一个解决办法是,禁用共享表空间功能,在MySQL配置文件my.cnf中将 innodb_file_per_table 设置为 ON ,强制所有表一定要拆分成独立的小表空间,这样将使得数据库在管理上变得更加简单。
总的来说,MySQL的ER_SHARED_TABLESPACE_USED_BY_PARTITIONED_TABLE错误,表明由于该MySQL的实现缺陷,无法正确处理分区表使用的共享表空间发生变更,因此解决方案可以是使用多个共享表空间,也可以是禁用共享表空间功能,强制所有表拆分成独立的小表空间。