• RENAME INDEX
    • 语法图
    • 示例
    • MySQL 兼容性
    • 另请参阅

    RENAME INDEX

    ALTER TABLE .. RENAME INDEX 语句用于对已有索引进行重命名。这在 TiDB 中是即时操作的,仅需更改元数据。

    语法图

    AlterTableStmt:

    AlterTableStmt

    KeyOrIndex:

    KeyOrIndex

    示例

    1. mysql> CREATE TABLE t1 (id INT NOT NULL PRIMARY KEY auto_increment, c1 INT NOT NULL, INDEX col1 (c1));
    2. Query OK, 0 rows affected (0.11 sec)
    3. mysql> SHOW CREATE TABLE t1\G
    4. *************************** 1. row ***************************
    5. Table: t1
    6. Create Table: CREATE TABLE `t1` (
    7. `id` int(11) NOT NULL AUTO_INCREMENT,
    8. `c1` int(11) NOT NULL,
    9. PRIMARY KEY (`id`),
    10. KEY `col1` (`c1`)
    11. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
    12. 1 row in set (0.00 sec)
    13. mysql> ALTER TABLE t1 RENAME INDEX col1 TO c1;
    14. Query OK, 0 rows affected (0.09 sec)
    15. mysql> SHOW CREATE TABLE t1\G
    16. *************************** 1. row ***************************
    17. Table: t1
    18. Create Table: CREATE TABLE `t1` (
    19. `id` int(11) NOT NULL AUTO_INCREMENT,
    20. `c1` int(11) NOT NULL,
    21. PRIMARY KEY (`id`),
    22. KEY `c1` (`c1`)
    23. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
    24. 1 row in set (0.00 sec)

    MySQL 兼容性

    RENAME INDEX 语句与 MySQL 完全兼容。如有任何兼容性差异,请在 GitHub 上提交 issue。

    另请参阅

    • SHOW CREATE TABLE
    • CREATE INDEX
    • DROP INDEX
    • SHOW INDEX