当前位置: 首页 > news >正文

专注做动漫的门户网站360营销

专注做动漫的门户网站,360营销,国外域名网站推荐,手机网站内容模块有几张表数据量非常大,一次维护量有点大(一个月有500多万条数据,并且还在往上涨), 于是想了个定时删除数据,每天凌晨执行,这样每天删除数据量就小, 循环删除,每次删除5…

有几张表数据量非常大,一次维护量有点大(一个月有500多万条数据,并且还在往上涨),

于是想了个定时删除数据,每天凌晨执行,这样每天删除数据量就小,

循环删除,每次删除5000条数据,直到当天的数据删除完:

1,做删除过程:

CREATE DEFINER=`root`@`%` PROCEDURE `S_delete_data2`()
BEGIN

        
    #当次删除行数
    declare delrows_int int default 0;

    #删除月份量
    declare Month_int int default -12;    

    #条件为真循环
    loop_label:LOOP

                
        #开启事务(重要!不开的话,100w数据需要论天算)
        start transaction;
        
        #测试_删除6个月前的数据
        #delete FROM user01 where get_day < DATE_ADD(CURRENT_DATE,INTERVAL Month_int MONTH) LIMIT 10000;
        #SET delrows_int = delrows_int + ROW_COUNT();  #每删除表记录下删除行数
        #select delrows_int;


        #删除语句,删除12个月以前的数据,限制每次删除5000条,多张表删除
        delete from t_report_167 where SampleTime < DATE_ADD(CURRENT_DATE,INTERVAL Month_int MONTH) LIMIT 5000;
        SET delrows_int = delrows_int + ROW_COUNT();  #每删除表记录下删除行数

        delete from t_report_big_167 where SampleTime < DATE_ADD(CURRENT_DATE,INTERVAL Month_int MONTH) LIMIT 5000;
        SET delrows_int = delrows_int + ROW_COUNT();  #每删除表记录下删除行数


        IF delrows_int=0 THEN
            LEAVE loop_label;  #退出循环
        END IF;
        #测试值显示
        #select delrows_int;
        
        IF @@ERROR_COUNT > 0 THEN    #判断事务成功与否
                ROLLBACK;
        ELSE    
                COMMIT;
        END IF;   
                
        SET delrows_int =0; #下次改为0
        
        #SELECT SLEEP(3) AS 'Waiting'; #暂停5秒,接收数据库其它操作,防止卡死
    
    END LOOP loop_label;
    
END
;

2,生成一个定时任务

#创建定时任务(任务名称delete_data)
#创建一个每天定时删除,3点过5分 ,调用过程S_delete_data2()
create event delete_data
ON schedule every 1 day starts DATE_ADD(DATE_ADD(DATE_ADD(CURRENT_DATE(),INTERVAL 1 DAY),INTERVAL 3 HOUR),INTERVAL 5 MINUTE)
do call S_delete_data2();

3,事件调度器必须开启才有效

查看事件调度器是否开启
SHOW VARIABLES LIKE 'event_scheduler';

#开启事件调度器(如果没有开启的话,执行下面)
SET GLOBAL event_scheduler = ON;

4,查看定时任务事件
SELECT event_name,event_definition,interval_value,interval_field,status FROM information_schema.EVENTS;

5,删除定时任务(delete_data是任务名称)
drop event delete_data;

标记下,以后查用

http://www.ds6.com.cn/news/118532.html

相关文章:

  • 江西医院网站建设抖音关键词排名推广
  • 长沙公司网站设计报价it培训学校
  • 上海招聘网站建设佛山网站建设十年乐云seo
  • 嘉兴企业网站建设系统人民日报今天新闻
  • 深圳公明网站建设公司广州seo优化效果
  • 天津做网站认准津坤科技注册域名后如何建立网站
  • 推广工具新区seo整站优化公司
  • 洛阳新光建站百度人工优化
  • 武汉网站开发首选千捷科技故事式软文范例500字
  • 支付功能网站建设刷关键词要刷大词吗
  • 如何做视频会员网站网络推广公司口碑
  • 网站首页排名下降seo编辑培训
  • 网站开发网站定制灰色关键词排名代发
  • 长沙网站推广公司爱站网影院
  • 做网页链接网站百度关键词seo优化
  • 织梦做旅游网站化工网站关键词优化
  • 做网站 sql 用哪种百度快照关键词推广
  • 我的世界大盒子怎么做视频网站seo搜索引擎优化公司
  • 合肥网站建设合肥网站制作四川最好的网络优化公司
  • 网站建设项目国内外分析报告网站seo是啥
  • 做网站需要几步石家庄seo外包公司
  • 树状结构的网站网站快速推广
  • 广州思盾互动网站建设公司世界足球排名前100名
  • 网站建设公司专业公司哪家好外贸网站谷歌seo
  • 官方网站免费建设企业宣传软文
  • 郑州大学第一附属医院深圳网络优化公司
  • 中国工程建设交易信息网站可以免费发帖的网站
  • 深圳品牌营销网站建设搜狗指数官网
  • 网站推广的看法外链工具xg下载
  • 建的网站打开很慢石家庄做网站推广排名的公司