前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >【教程】truncate清空表数据,为什么数据库的空间还是和原来一样并没有释放|truncate table 空间没有释放|数据库释放表空间教程|

【教程】truncate清空表数据,为什么数据库的空间还是和原来一样并没有释放|truncate table 空间没有释放|数据库释放表空间教程|

作者头像
小小鱼儿小小林
发布2024-05-25 14:35:25
发布2024-05-25 14:35:25
1.1K00
代码可运行
举报
文章被收录于专栏:灵儿的笔记灵儿的笔记
运行总次数:0
代码可运行

前言

我们经常会被问到delete和truncate的区别,然后我们经常回答delete是删除表数据,truncate是清空表,

但是你有没有想过,当你用truncate清空表数据的时候,为什么数据库的空间还是和原来一样并没有释放?

一、为什么truncate不会立即释放表空间

那是因为当使用truncate命令清空表数据时,数据库并不会立即释放空间。相反,它会将空间标记为可重用,以便在以后插入新数据时可以使用。这是因为truncate命令是一种快速清空表数据的方法,它不会逐行删除数据,而是直接删除整个表的数据。因此,数据库并不会像使用delete命令一样逐行删除数据并释放空间。如果您想要立即释放空间,可以使用alter table命令来重建表,或使用vacuum命令来清理数据库中的未使用空间。

二、如何使用VACUUM命令来清理数据库中未使用的空间

代码语言:javascript
代码运行次数:0
复制
VACUUM命令是用于清理数据库中未使用空间的命令。它可以回收已删除行所占用的空间,并将空间标记为可重用。以下是使用VACUUM命令的步骤:
1. 打开数据库命令行或客户端工具。
2. 连接到要清理的数据库。
3. 在命令行或客户端工具中输入以下命令:
VACUUM;

4. 执行命令后,数据库将开始清理未使用空间。这可能需要一些时间,具体取决于数据库的大小和复杂性。
5. 当命令完成后,您可以关闭数据库命令行或客户端工具。

请注意,VACUUM命令可能会对数据库的性能产生一定影响,因此建议在低峰期执行此命令。此外,如果您的数据库经常进行大量的插入、更新和删除操作,建议定期执行VACUUM命令以确保数据库的性能和空间利用率。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-04-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 一、为什么truncate不会立即释放表空间
  • 二、如何使用VACUUM命令来清理数据库中未使用的空间
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档