PostgreSQL删除清空表,truncate、delete、drop

主题:删除表时,如果要释放空间,需要使用TRUNCATE。

一、TRUNCATE

语法:TRUNCATE TABLE table_name;

示例:

sql 复制代码
TRUNCATE TABLE gd_4528_2020 

二、delete和drop

sql 复制代码
delete from dltb_350623_2021 where id<>158
sql 复制代码
DROP TABLE demo_contacts

三、三者比较

1、TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。

使用TRUNCATE删除后,postgre的占用空间将被释放:

2、truncate与drop是DDL语句,执行后无法回滚;delete是DML语句,可回滚。

3、truncate只能作用于表;delete,drop可作用于表、视图等。

4、truncate会清空表中的所有行,且不能带where,但表结构及其约束、索引等保持不变;drop会删除表的结构及其所依赖的约束、索引等。

5、truncate会重置表的自增值;delete不会。

6、truncate不会激活与表有关的删除触发器;delete可以。

7、truncate后会使表和索引所占用的空间会恢复到初始大小;delete操作不会减少表或索引所占用的空间,drop语句将表所占用的空间全释放掉。

相关推荐
元亓亓亓21 分钟前
MySQL--day2--基本的select语句
数据库·mysql
辛普森Mmmm30 分钟前
Mysql数据库详解
数据库·mysql
冬瓜的编程笔记35 分钟前
【MySQL成神之路】MySQL常见命令汇总
数据库·mysql
FBI HackerHarry浩41 分钟前
Linux云计算训练营笔记day10(MySQL数据库)
linux·运维·数据库·笔记·mysql
20242817李臻1 小时前
李臻20242817_安全文件传输系统项目报告_第12周
数据库·安全
vvilkim1 小时前
MySQL 用户权限管理:从入门到精通
数据库·mysql
奔驰的小野码1 小时前
MySQL8.x新特性:与mysql5.x的版本区别
数据库·mysql
lml48561 小时前
MySQL高可用
数据库·mysql
YUNYINGXIA1 小时前
MySQL高可用
数据库·mysql
小芳矶2 小时前
【全网首发】解决coze工作流批量上传excel数据文档数据重复的问题
数据库·oracle·excel