重命名数据库、表或字典。 可以在单个查询中重命名多个实体。
注意
具有多个实体的**RENAME
**查询是非原子操作。
重命名数据库。
RENAME DATABASE atomic_database1 TO atomic_database2 [,...]
重命名一个或多个表。
重命名表是一个轻量级的操作。 如果在**TO
之后传递一个不同的数据库,该表将被移动到这个数据库。 但是,包含数据库的目录必须位于同一文件系统中。 否则,返回错误。 如果在一个查询中重命名多个表,则该操作不是原子操作。 可能会部分执行,其他会话中可能会得到Table ... does not exist ...
**错误。
RENAME TABLE [tableIdentifier] TO [tableIdentifier], [tableIdentifier] TO [tableIdentifier]
-- step 1: create a table CREATE TABLE `example_table` ( `a` Int8, `b` String, `c` Date ) ENGINE = `MergeTree` ORDER BY (`a`) -- step 2: rename the new created table RENAME TABLE example_table to new_table_name
重命名一个或多个词典。 此查询可用于在数据库之间移动字典。
RENAME DICTIONARY [db0.]dict_A TO [db1.]dict_B [,...]