Postgresql 删除数据表
在 PostgreSQL 中,删除数据表可以使用 DROP TABLE 语句。这个操作会永久删除指定的表及其所有数据。操作前请确保你确实要删除表,因为一旦删除,表中的数据将无法恢复。
基本语法
DROP TABLE [ IF EXISTS ] name [, ...] [ CASCADE | RESTRICT ]
参数说明
IF EXISTS -- 如果表不存在,则不要引发错误。在这种情况下,将发出通知。
name -- 要删除的表的名称(可选模式限定)。
CASCADE -- 自动删除依赖于 table 的对象 (例如 views),进而删除依赖于这些对象的所有对象。
RESTRICT -- 如果任何对象依赖于该表,则拒绝删除该表。这是默认设置。
使用示例
删除单张表
DROP TABLE students;
删除多张表
DROP TABLE students,classes;
特别说明
DROP TABLE 从数据库中删除表。只有表所有者、架构所有者和超级用户才能删除表。要在不销毁表的情况下清空行表,请使用 DELETE 或 TRUNCATE。
DROP TABLE 始终删除目标表存在的任何索引、规则、触发器和约束。但是,要删除由视图或另一个表的外键约束引用的表,必须指定 CASCADE。(CASCADE 将完全删除依赖视图,但在外键情况下,它只会删除外键约束,而不会完全删除另一个表。