受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

DROP TABLE

DROP TABLE — 移除一个表

Synopsis

DROP TABLE [ IF EXISTS ] name [, ...] [ CASCADE | RESTRICT ]

描述

DROP TABLE从数据库中移除表。 只有表拥有者、模式拥有者以及超级用户才能删除表。 若要清空表中的行而不销毁该表,请使用 DELETETRUNCATE

DROP TABLE总会移除目标表上存在的所有索引、规则、触发器和约束。 但是,要删除一个被视图或另一张表的外键约束引用的表,必须指定CASCADE。 (CASCADE会将依赖于该表的视图整个删除,但在外键场景下,它只会删除外键约束, 不会把另一张表整体删除。)

参数

IF EXISTS

如果该表不存在,则不要抛出错误。这种情况下会发出一个提示。

name

要删除的表名称(可选地使用模式限定)。

CASCADE

自动删除依赖于该表的对象(例如视图),以及进一步依赖于这些对象的所有对象 (参见Section 5.15)。

RESTRICT

如果有任何对象依赖于该表,则拒绝删除它。这是默认值。

示例

要删除两个表filmsdistributors

DROP TABLE films, distributors;

兼容性

此命令符合 SQL 标准,只是标准每条命令只允许删除一个表, 且IF EXISTS选项是PostgreSQL扩展。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。