跳到主要内容

UNDROP TABLE

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

参见:

语法

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

    Examples:
    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 角色可见。

    Examples:
    GRNAT OWNERSHIP on doc.t to ROLE writer;

示例

CREATE TABLE test(a INT, b VARCHAR);

-- drop table
DROP TABLE test;

-- show dropped tables from current database
SHOW TABLES HISTORY;

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

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