日志表数据太多,进行删除部分数据操作

由于项目运行了好几年,数据库中的日志表的数据量比较大,如果使用常规的删除语句进行删除的话,需要很长的时间,并且不一定能删除掉。

TRUNCATE TABLE 表

使用TRUNCATE TABLE时需要注意,以下表不能使用TRUNCATE TABLE:

1、由 FOREIGN KEY 约束引用的表。

2、参与索引视图的表。

3、通过使用事务复制或合并复制发布的表

1、创建 与”sys_log“表结构一样的临时表sys_log_old

CREATE TABLE sys_log_old SELECT * FROM sys_log WHERE 1=2;

2、把表(sys_log)中的部分数据,保存到临时表(sys_log_old)中

INSERT INTO sys_log_old SELECT * FROM sys_log WHERE sys_log.create_time > '2022-08-01 00:00:01'

3、清空日志表( sys_log)

TRUNCATE TABLE sys_log;

4、删除日志表

drop table sys_log

5、把临时表(sys_log_old)更改成日志表(sys_log)

rename table sys_log_old to sys_log

以上方式,对于数据达到千万以上的日志表处理会达到一个非常满意的效果

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值