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

你可能感兴趣的:(mysql中触发器,删除表数据)