跳到主要内容

UNDROP TABLE

恢复最近删除的表。此功能利用了 Databend 的时间回溯特性;删除的对象只能在保留期内(默认为 24 小时)恢复。

另请参阅:

语法

UNDROP TABLE [ <database_name>. ]<table_name>
  • 如果已经存在同名的表,将返回错误。

    示例:
    root@localhost:8000/default> CREATE TABLE t(id INT);
    processed in (0.036 sec)

    root@localhost:8000/default> DROP TABLE t;
    processed in (0.033 sec)

    root@localhost:8000/default> CREATE TABLE t(id INT, name STRING);
    processed in (0.030 sec)

    root@localhost:8000/default> UNDROP TABLE t;
    error: APIError: QueryFailed: [2308]Undrop Table 't' already exists
  • 恢复表不会自动将所有权恢复到原始角色。恢复后,必须手动将所有权授予之前的角色或其他角色。在此之前,只有 account-admin 角色可以访问该表。

    示例:
    GRNAT OWNERSHIP on doc.t to ROLE writer;

示例

CREATE TABLE test(a INT, b VARCHAR);

-- 删除表
DROP TABLE test;

-- 显示当前数据库中已删除的表
SHOW TABLES HISTORY;

┌────────────────────────────────────────────────────┐
│ Tables_in_orders_2024 │ drop_time │
├───────────────────────┼────────────────────────────┤
│ test │ 2024-01-23 04:56:34.766820
└────────────────────────────────────────────────────┘

-- 恢复表
UNDROP TABLE test;
开始使用 Databend Cloud
低成本
快速分析
多种数据源
弹性扩展
注册