使用触发器自动从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;
上一篇:MySQL触发器插入和删除在一个?


下一篇:关于confluent集成环境的启动问题,为什么无法一键全部启动,而是报错Error: ZooKeeper failed to start