PostgreSQL清空数据库的常用方法

 更新时间:2026年03月18日 08:33:44   作者:亮子AI  
PostgreSQL 中清空一个数据库通常有几种理解和对应方法,具体取决于你的需求,本文通过代码示例给大家介绍了常用的清空方法,需要的朋友可以参考下

PostgreSQL 中“清空一个数据库”通常有几种理解和对应方法,具体取决于你的需求:

  • 只清空所有数据(保留表结构、索引、约束等):推荐使用 TRUNCATE
  • 彻底清空(删除所有表、视图、序列等对象,保留空数据库):推荐 DROP SCHEMA + CREATE SCHEMA
  • 完全删除并重建数据库:最简单粗暴的方式。

注意事项(非常重要)

  • 操作前备份数据!清空是不可逆的。
  • 需要超级用户或数据库所有者权限。
  • 大部分操作会锁定表,生产环境慎用。
  • 如果有外键约束,TRUNCATEDROP 可能需要加 CASCADE

1. 最推荐:只清空数据(保留表结构)—— 使用 TRUNCATE

TRUNCATEDELETE 快得多,且立即释放空间。

方法 A:手动清空单个或多个表

TRUNCATE TABLE table1, table2, table3 RESTART IDENTITY CASCADE;
  • RESTART IDENTITY:同时重置自增序列(序列从 1 开始)。
  • CASCADE:自动清空有外键引用的表(小心使用)。

方法 B:自动清空当前 schema(通常是 public)中的所有表

在 psql 中执行以下脚本:

DO $$
DECLARE
    r RECORD;
BEGIN
    FOR r IN (SELECT tablename FROM pg_tables WHERE schemaname = current_schema()) LOOP
        EXECUTE 'TRUNCATE TABLE ' || quote_ident(r.tablename) || ' RESTART IDENTITY CASCADE;';
    END LOOP;
END $$;

或者生成 SQL 后执行(更灵活):

SELECT 'TRUNCATE TABLE ' || tablename || ' RESTART IDENTITY CASCADE;'
FROM pg_tables 
WHERE schemaname = 'public';

复制输出结果并执行即可。

2. 彻底清空数据库(删除所有对象,保留空库)

最简单高效的方式是删除并重建默认 schema(public):

DROP SCHEMA public CASCADE;
CREATE SCHEMA public;

-- 恢复默认权限(推荐加上)
GRANT ALL ON SCHEMA public TO postgres;
GRANT ALL ON SCHEMA public TO public;

这会删除所有表、视图、函数、序列等,数据库本身还在,但已经是空的。

3. 完全删除并重建整个数据库

使用 SQL(需要在 postgres 或其他数据库中执行,不能在目标数据库里删自己)

DROP DATABASE IF EXISTS your_database_name;
CREATE DATABASE your_database_name;

使用命令行工具(推荐)

# 删除数据库
dropdb -U postgres your_database_name
# 创建新数据库
createdb -U postgres your_database_name

或者用 pgAdmin 图形界面操作更直观。

4. 其他常见场景

  • 清空后重置序列:在 TRUNCATE 时加 RESTART IDENTITY,或单独执行 ALTER SEQUENCE seq_name RESTART WITH 1;
  • 释放磁盘空间:清空后如果空间没释放,可执行:
VACUUM FULL;

(会锁表,生产环境慎用;平时用 VACUUM 即可)。

  • 只删除数据不重置序列TRUNCATE ... CONTINUE IDENTITY;(默认行为)。

建议

  • 开发/测试环境:用方法 2(DROP SCHEMA)最方便。
  • 生产环境:强烈建议用方法 1(TRUNCATE),并在事务中测试。
  • 如果数据库很大,TRUNCATE 仍然是最快的清空方式。

到此这篇关于PostgreSQL清空数据库的常用方法的文章就介绍到这了,更多相关PostgreSQL清空数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SQLCipher数据迁移到PostgreSql详细教程

    SQLCipher数据迁移到PostgreSql详细教程

    这篇文章主要介绍了SQLCipher数据迁移到PostgreSql详细教程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-09-09
  • Postgresql ALTER语句常用操作小结

    Postgresql ALTER语句常用操作小结

    这篇文章主要介绍了Postgresql ALTER语句常用操作小结,本文讲解了增加一列、删除一列、更改列的数据类型、表的重命名、更改列的名字、字段的not null设置等常用操作的代码示例,需要的朋友可以参考下
    2015-06-06
  • PostgreSQL打印实时查询语句的三种方法

    PostgreSQL打印实时查询语句的三种方法

    这篇文章主要介绍了三种PostgreSQL实时打印查询的方法:1.通过日志配置记录所有SQL;2.利用pg_stat_activity监控活跃查询;3.使用pg_stat_statements分析历史性能,并提醒生产环境应避免全量记录以减少性能损耗,需要的朋友可以参考下
    2025-09-09
  • postgresql 索引之 hash的使用详解

    postgresql 索引之 hash的使用详解

    这篇文章主要介绍了postgresql 索引之 hash的使用详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Docker环境实现PostgreSQL自动备份的流程步骤

    Docker环境实现PostgreSQL自动备份的流程步骤

    本文详细介绍了如何在Ubuntu系统中安装Docker,然后在Docker容器内安装和配置PostgreSQL数据库,接着,重点讲解了如何在PostgreSQL中安装和配置pg_rman工具,用于数据库的备份和恢复操作,文章还涵盖了创建定时备份任务以及删除备份的步骤,需要的朋友可以参考下
    2024-11-11
  • 解决postgresql 序列跳值的问题

    解决postgresql 序列跳值的问题

    这篇文章主要介绍了解决postgresql 序列跳值的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • PostgreSQL使用IP无法连接的解决方法

    PostgreSQL使用IP无法连接的解决方法

    这篇文章主要介绍了PostgreSQL使用localhost可以连接/使用IP无法连接的问题解决,需要的朋友可以参考下
    2018-01-01
  • CentOS 9 Stream 上安装 PostgreSQL 16的步骤

    CentOS 9 Stream 上安装 PostgreSQL 16的步

    在CentOS9Stream上安装PostgreSQL16,首先添加PostgreSQL官方仓库,然后禁用系统自带PostgreSQL版本,避免冲突,使用dnf命令安装PostgreSQL16,并初始化数据库,本文给大家介绍CentOS 9 Stream 上安装 PostgreSQL 16的步骤,感兴趣的朋友一起看看吧
    2024-11-11
  • PostgreSQL向量检索之pgvector入门实战指南

    PostgreSQL向量检索之pgvector入门实战指南

    pgvector是PostgreSQL的开源扩展,用于在数据库中存储和处理向量数据,特别是高维嵌入向量(embedding),本文介绍PostgreSQL向量检索:pgvector入门指南,感兴趣的朋友一起看看吧
    2026-01-01
  • PostgreSQL 创建表分区

    PostgreSQL 创建表分区

    在pg里表分区是通过表继承来实现的,一般都是建立一个主表,里面是空,然后每个分区都去继承它。
    2009-09-09

最新评论