RENAME INDEX
语句 ALTER TABLE .. RENAME INDEX
用于将现有索引重命名为新名称。 在 TiDB 中,此操作是即时的,只需更改元数据。
概要
- AlterTableStmt
- RenameIndexSpec
AlterTableStmt
::= 'ALTER' 'IGNORE'? 'TABLE' TableName RenameIndexSpec ( ',' RenameIndexSpec )*
RenameIndexSpec
::= 'RENAME' ( 'KEY' | 'INDEX' ) Identifier 'TO' Identifier
示例
mysql> CREATE TABLE t1 (id INT NOT NULL PRIMARY KEY AUTO_INCREMENT, c1 INT NOT NULL, INDEX col1 (c1));
Query OK, 0 rows affected (0.11 sec)
mysql> SHOW CREATE TABLE t1\G
*************************** 1. row ***************************
Table: t1
Create Table: CREATE TABLE `t1` (
`id` int NOT NULL AUTO_INCREMENT,
`c1` int NOT NULL,
PRIMARY KEY (`id`),
KEY `col1` (`c1`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
1 row in set (0.00 sec)
mysql> ALTER TABLE t1 RENAME INDEX col1 TO c1;
Query OK, 0 rows affected (0.09 sec)
mysql> SHOW CREATE TABLE t1\G
*************************** 1. row ***************************
Table: t1
Create Table: CREATE TABLE `t1` (
`id` int NOT NULL AUTO_INCREMENT,
`c1` int NOT NULL,
PRIMARY KEY (`id`),
KEY `c1` (`c1`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
1 row in set (0.00 sec)
MySQL 兼容性
TiDB 中的 RENAME INDEX
语句与 MySQL 完全兼容。如果你发现任何兼容性差异,请报告一个 bug。