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条)

报告相同问题?

悬赏问题

  • ¥20 关于CMOS电路图的提问
  • ¥15 Verilog hdl密码锁设计
  • ¥15 CreateFile无法获取特殊文件内容
  • ¥35 基于python的有ssl加密传输的socket聊天室
  • ¥15 数码管亮度控制器设计
  • ¥15 kafka客户端跨网段访问,看日志提示连接的还剩内网地址,且访问不通
  • ¥15 关于c语言代码的问题
  • ¥15 c51单片机控制步进电机
  • ¥20 Visual studio无法检测到设备
  • ¥30 vue 页面窗口放大或者缩小元素会变化