有人可以为我提供一个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;