【PostgreSQL】如何清空数据库?

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

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

注意事项(非常重要)

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

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

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

方法 A:手动清空单个或多个表
sql 复制代码
TRUNCATE TABLE table1, table2, table3 RESTART IDENTITY CASCADE;
  • RESTART IDENTITY:同时重置自增序列(序列从 1 开始)。
  • CASCADE:自动清空有外键引用的表(小心使用)。
方法 B:自动清空当前 schema(通常是 public)中的所有表

在 psql 中执行以下脚本:

sql 复制代码
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 后执行(更灵活):

sql 复制代码
SELECT 'TRUNCATE TABLE ' || tablename || ' RESTART IDENTITY CASCADE;'
FROM pg_tables 
WHERE schemaname = 'public';

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

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

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

sql 复制代码
DROP SCHEMA public CASCADE;
CREATE SCHEMA public;

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

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

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

使用 SQL(需要在 postgres 或其他数据库中执行,不能在目标数据库里删自己)
sql 复制代码
DROP DATABASE IF EXISTS your_database_name;
CREATE DATABASE your_database_name;
使用命令行工具(推荐)
bash 复制代码
# 删除数据库
dropdb -U postgres your_database_name

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

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

4. 其他常见场景

  • 清空后重置序列 :在 TRUNCATE 时加 RESTART IDENTITY,或单独执行 ALTER SEQUENCE seq_name RESTART WITH 1;

  • 释放磁盘空间 :清空后如果空间没释放,可执行:

    sql 复制代码
    VACUUM FULL;

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

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

建议

  • 开发/测试环境:用方法 2(DROP SCHEMA)最方便。
  • 生产环境:强烈建议用方法 1(TRUNCATE),并在事务中测试。
  • 如果数据库很大,TRUNCATE 仍然是最快的清空方式。
相关推荐
TDengine (老段)3 分钟前
工业软件的未来:构建在工业数据底座之上的 AI Agent
大数据·数据库·人工智能·时序数据库·tdengine
qq_349317483 分钟前
Tailwind CSS如何自定义间距数值_配置theme spacing扩展CSS边距
jvm·数据库·python
coderlin_5 分钟前
Langgraph项目三 agent搭建
java·数据库·redis
xyx-3v8 分钟前
信号量(二进制/计数)
java·linux·数据库
u01102251216 分钟前
HTML5多媒体资源动态替换Source标签的刷新机制
jvm·数据库·python
云祺vinchin20 分钟前
“十五五”引领灾备升级,数字化安全建设如何合规落地?
网络·数据库·安全·kubernetes·数据安全·容灾备份
当战神遇到编程22 分钟前
关系型数据库设计基础:约束、三大范式、表关系与表设计流程
数据库
其实防守也摸鱼30 分钟前
《SQL注入进阶实验:基于sqli-Labs的报错注入(Error-Based Injection)实战解析》
网络·数据库·sql·安全·网络安全·sql注入·报错注入
Ting.~31 分钟前
软件设计师备考笔记【day3】-数据库
数据库·笔记
Bert.Cai32 分钟前
MySQL FLOOR()函数详解
数据库·mysql