mysql中触发器 删除表数据,使用触发器自动从mysql数据库的日志表中删除行

有人可以为我提供一个mysql 5触发器创建代码,当我的表中的行总数达到y时,该代码将允许我删除表中的前x个行吗?

谢谢

解决方法:

您无法在触发触发器的同一表上执行任何CRUD操作…因此,无法在表上使用触发器来完成此操作

但是,您可以使用两个查询的序列.由于它是一个日志表,因此第二个是否失败可能无关紧要.偶尔,计算总行数并再次调整其大小.

INSERT INTO LOGTABLE ..... # 1 record

DELETE FROM LOGTABLE ORDER BY ID LIMIT 1;

编辑:更好的解决方法

一个更明智的选择是安排将运行该批处理的作业(Windows任务计划程序mysql.exe或linux cron),该批处理仅保留100(更改为适合)记录

set @sql := (select count(*) from logtable) - 100;

set @sql := concat('delete from logtable order by date limit ', @sql);

PREPARE stmt FROM @sql;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

标签:logging,sql,mysql,triggers

来源: https://codeday.me/bug/20191208/2094115.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值