tianchao_ 2013-05-08 14:40 采纳率: 100%
浏览 267
已采纳

mysql 定时备份表 新建表

需求:MySQl每月最后一天的晚上00:00:00点 ,将表log_user_audio的名字改为log_user_audio_2013_01_31 ,然后新建一个表log_user_audio

问题:
1:这个怎么写,或者帮我找找,因为我不知道怎么搜 --! 囧囧?

2:这个是用所谓的存储过程实现吗? 我一点不了解数据库除了sql之外的东西,能不能顺便帮忙开导下我?

  • 写回答

1条回答 默认 最新

  • zyn010101 2013-05-08 15:55
    关注

    [code="java"]create procedure alterTable()
    begin
    declare yestodayDate varchar(10);
    declare lastMonthlastDay varchar(10);
    select date_format(date_add(curdate(), interval -1 day),'%Y-%m-%d') into yestodayDate;
    select last_day(date_add(curdate(), interval -1 day)) into lastMonthlastDay;
    if lastMonthlastDay== yestodayDate then
    alter table a rename to concat('log_user_audio_',date_format(date_add(curdate(), interval -1 day),'%Y'),'_',date_format(date_add(curdate(), interval -1 day),'%m'),'_',date_format(date_add(curdate(), interval -1 day),'%d'));
    set @STMT := concat(
    "create table log_user_audio
    (f_user_id varchar(64) not null,
    f_user_name varchar(100),
    f_time_stamp timestamp,
    primary key (f_user_id)
    )ENGINE=MyISAM DEFAULT CHARSET=utf8;
    ");

                /*执行创建用户信息表的sql*/
                prepare stmt from @STMT;
                execute stmt;
    
    end if;
    

    end[/code]

    [code="java"]
    CREATE EVENT event_alter_table ON SCHEDULE EVERY 1 HOUR STARTS '2013-04-15 11:30:00' ON COMPLETION PRESERVE ENABLE DO call alterTable()
    ;;
    DELIMITER ;
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?