MySQL的delete操作与数据库空间

delete删除记录只是给数据库中的记录加一个删除标识了,这样数据库空间并不是减少了。一般表drop truncate操作才会直接释放空间的。delete 不会释放空间。在实际的使用中,我们会使用比较多的delete操作,这就会导致数据库的空间资源浪费。

常见的delete使用方式:

  1. 当delete后面跟条件时(这是比较常见的现象)
  2. 不带条件的delete

使用1的方法删除数据后,表的空间大小不会改变。使用2的方法删除数据后表的空间大小为0。

当使用方法1删除数据导致数据库的空间资源浪费的问题的时候可以通过使用optimize table指令来对表进行优化。
命令语法:OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...
最简单的:optimize table phpernote_article;
OPTIMIZE TABLE只对MyISAM, BDB和InnoDB表起作用

注意: 在OPTIMIZE TABLE运行过程中,MySQL会锁定表。因此,这个操作一定要在网站访问量较少的时间段进行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值