kelifan 2021-06-18 00:56 采纳率: 100%
浏览 114
已采纳

mysql如何定时查询数据并建立新表

如题,怎么样让数据库定时每月1日查询下表a取下b、c、d并将数据另外生成一个表,表名为202106这样,

  • 写回答

5条回答 默认 最新

  • 清枫cc 2021-06-18 08:40
    关注
    -- 启用事件调度器
    SET GLOBAL event_scheduler = 1;
    
    -- 创建任务存过
    DELIMITER $$
    CREATE PROCEDURE PROC_TEST1()
    BEGIN
    	SET @sqlstr = CONCAT(' CREATE TABLE test_',DATE_FORMAT(now(),'%Y%m') ,' AS SELECT * FROM tb1');
    	PREPARE stmt1 FROM @sqlstr ;
    	EXECUTE stmt1 ; 
    END $$
    DELIMITER ;
    
    -- 创建每月定时任务
    CREATE EVENT TEST_MONTH_JOB
    ON SCHEDULE EVERY 1 MONTH 
    STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY), INTERVAL 1 MONTH),INTERVAL 0 HOUR)
    DO
    CALL PROC_TEST1();
    
    生成如下表
    test_202106
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 用C语言输入方程怎么
  • ¥15 网站显示不安全连接问题
  • ¥15 github训练的模型参数无法下载
  • ¥15 51单片机显示器问题
  • ¥20 关于#qt#的问题:Qt代码的移植问题
  • ¥50 求图像处理的matlab方案
  • ¥50 winform中使用edge的Kiosk模式
  • ¥15 关于#python#的问题:功能监听网页
  • ¥15 怎么让wx群机器人发送音乐
  • ¥15 fesafe材料库问题