我们经常会被问到delete和truncate的区别,然后我们经常回答delete是删除表数据,truncate是清空表,
但是你有没有想过,当你用truncate清空表数据的时候,为什么数据库的空间还是和原来一样并没有释放?
一、为什么truncate不会立即释放表空间
那是因为当使用truncate命令清空表数据时,数据库并不会立即释放空间。相反,它会将空间标记为可重用,以便在以后插入新数据时可以使用。这是因为truncate命令是一种快速清空表数据的方法,它不会逐行删除数据,而是直接删除整个表的数据。因此,数据库并不会像使用delete命令一样逐行删除数据并释放空间。如果您想要立即释放空间,可以使用alter table命令来重建表,或使用vacuum命令来清理数据库中的未使用空间。
二、如何使用VACUUM命令来清理数据库中未使用的空间