使用存储过程定时对数据库表进行迁移

业务运行一段时间后,会出现有些表数据量很大,可能对系统性能产生不良的影响,常见的如订单表、登录log表等,这些数据很有时效性,比如我们一般很少去查上个月的订单,最多也就是报表统计会涉及到。

解决方案:创建一张与A表字段一样的B表,每天定时把A表昨天的数据插入到B表,再把A表昨天之前的数据删除,也可以根据需求改成一个月一次。如果不想只保存到一张表里,也可以在存储过程中,以年月份为后缀每次新建表。

1、首先创建一个存储过程

DELIMITER $

/*数据库名称*/

USE `dbcp`$$ 

/*存储过程名称*/

DROP PROCEDURE IF EXISTS `apaas_log_procedure`$$

CREATE DEFINER=`root`@`%` PROCEDURE `apaas_log_procedure`()

BEGIN

    SET @current_time = NOW();

    /*备份昨天之前的数据*/

    INSERT INTO `apaas_log_copy`

    SELECT * FROM `apaas_log`

    WHERE DATEDIFF(`create_Date`,@current_time) < 0;

    /*删除昨天之前的数据*/

    DELETE FROM `apaas_log`

    WHERE DATEDIFF(`create_Date`,@current_time) < 0;

    /*备份昨天之前的数据*/

    INSERT INTO `apaas_log_unqualified_copy`

    SELECT * FROM `apaas_log_unqualified`

    WHERE DATEDIFF(`create_Date`,@current_time) < 0;

    /*删除昨天之前的数据*/

    DELETE FROM `apaas_log_unqualified`

    WHERE DATEDIFF(`create_Date`,@current_time) < 0;

    END$$

DELIMITER ;

2、创建定时事件

DELIMITER $$

/*每天4点执行*/

ALTER DEFINER=`root`@`%` EVENT `apaas_log_event`

ON SCHEDULE EVERY 1 DAY STARTS '2019-02-19 04:00:00'

ON COMPLETION PRESERVE ENABLE DO CALL apaas_log_procedure()$$ 

DELIMITER ;

3.启动定时任务

/*启动定时任务*/

SET GLOBAL event_scheduler = 1

/*关闭定时任务*/

SET GLOBAL event_scheduler = 0

/*查看定时任务状态*/

SHOW VARIABLES LIKE '%event_sche%'

---------------------------------------------------------------------------

1.在使用之前必须确保 event_scheduler已开启

2.创建素具迁移的存储过程

DELIMITER $$

USE `yst_uic_service`$$

DROP PROCEDURE IF EXISTS `Sync_uchome_seen_history`$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `Sync_uchome_seen_history`(IN tabSize INT)

BEGIN

 DECLARE i INT DEFAULT 0;

## 获取需同步数据的时间节点(上个月)

SET @upmonth= DATE_ADD(NOW(), INTERVAL -1 MONTH);

WHILE i < tabSize DO

SET @sqlstr=CONCAT('INSERT INTO `uchome_history_',i,'`(`icon`,`uid`,`epgId`,`detailsId`,`score`,`titleData`,`datePoint`,`dateLine`,`objtype`,`templateId`,`times`,`watchTime`)

   SELECT `icon`,`uid`,`epgId`,`detailsId`,`score`,`titleData`,`datePoint`,`dateLine`,`objtype`,`templateId`,`times`,`watchTime` FROM `uchome_seen_',i,'`  WHERE `dateLine`<=?');     

SET @delsqlstr=CONCAT('delete from `uchome_seen_',i,'` WHERE `dateLine`<=? ');

#执行数据迁移

PREPARE _stmt FROM @sqlstr;

EXECUTE _stmt USING @upmonth;

DEALLOCATE PREPARE _stmt;

#执行迁移后的数据删除

PREPARE _stdel FROM @delsqlstr;

EXECUTE _stdel USING @upmonth;

DEALLOCATE PREPARE _stdel;

SET i := i+1;

END WHILE;

END$$

DELIMITER ;

3.创建定时任务

DELIMITER $$

ALTER DEFINER=`root`@`localhost` EVENT `Sync_uchome_seen_history`

 ON SCHEDULE EVERY 1 DAY

   STARTS '2015-06-29 01:30:00'

 ON COMPLETION NOT PRESERVE ENABLE

   DO CALL`Sync_uchome_seen_history`(10)$$

DELIMITER ;

4.关闭和开启任务时间

临时关闭: ALTER EVENT  Sync_uchome_seen_history  ON  COMPLETION PRESERVE DISABLE;

关闭任务 :  ALTER EVENT  Sync_uchome_seen_history DISABLE;

临时开启:  ALTER EVENT Sync_uchome_seen_histor

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Navicat Premium 12 是一款功能强大的数据库管理工具,可以帮助用户直接连接并同时管理多个数据库使用Navicat Premium 12非常简单方便。 首先,用户可以选择连接到本地或远程数据库。用户只需输入正确的主机名、端口号、用户名和密码,点击连接按钮即可完成连接。连接成功后,用户可以在左侧的导航窗格中看到数据库的列。 选择一个数据库后,用户可以在主窗口中浏览格、视图、存储过程等对象,也可以直接执行SQL查询。对于常用的数据库操作,Navicat Premium 12提供了图形化的界面,用户可以方便地创建、修改、删除格、字段和索引。此外,用户还可以导入和导出数据,将数据以不同的格式保存到本地。 Navicat Premium 12还提供了丰富的查询和过滤功能,可以帮助用户快速找到所需的数据。用户可以使用SQL编辑器编写复杂的查询语句,也可以使用图形化的查询生成器轻松创建查询。通过SQL代码自动完成功能,用户可以高效地编写代码。同时,Navicat Premium 12还支持多线程查询,提高查询的效率。 值得一提的是,Navicat Premium 12还支持数据同步和备份功能。用户可以方便地将数据从一个数据库同步到另一个数据库,也可以定时备份数据库,保证数据的安全性。 总之,Navicat Premium 12直接使用非常简单,功能强大且易于操作。无论是初学者还是专业人士,都能够轻松地使用这款软件进行数据库管理。 ### 回答2: Navicat Premium 12是一款功能强大的数据库管理工具,可以帮助用户轻松地管理和操作各种类型的数据库。下面是关于如何直接使用Navicat Premium 12的简要说明: 首先,在安装完Navicat Premium 12后,打开该程序。用户将看到一个用户友好的界面,其中包含了各种功能选项和菜单。 用户可以选择创建一个新的数据库连接,点击上方的“连接”按钮,然后选择所需的数据库类型,如MySQL、Oracle、SQLite等。随后,用户需要填写相应的连接信息,如主机名、用户名、密码等。 连接成功后,用户可以通过简单地点击导航栏中的不同数据库对象,如、视图、存储过程等,来浏览和管理数据库中的内容。用户可以通过右键点击这些对象,选择不同的操作,如编辑、复制、删除等。 此外,Navicat Premium 12还提供了一个强大的查询构建器,可以帮助用户轻松地创建和执行复杂的SQL查询。用户只需要选择所需的和字段,然后使用可视化工具构建查询,并通过点击运行按钮来执行查询。 另一个便捷的功能是数据传输向导。用户可以通过该功能将数据从一个数据库迁移到另一个数据库,只需简单地选择源和目标数据库以及要传输的,然后点击开始按钮。 此外,Navicat Premium 12还提供了许多其他实用的功能,如数据备份和还原、数据同步、数据导入和导出等。 总而言之,Navicat Premium 12是一款功能强大且易于使用数据库管理工具,可以极大地简化用户对数据库的操作和管理。用户只需按照以上简要说明,利用导航栏和工具栏提供的功能选项,即可直接使用Navicat Premium 12。 ### 回答3: Navicat Premium 12是一款功能强大的数据库管理工具。使用Navicat Premium 12能够轻松连接多种不同类型的数据库,并提供了直观简便的用户界面,使得数据库管理变得更加便捷。下面是Navicat Premium 12直接使用的一些步骤和功能介绍。 首先,您需要下载和安装Navicat Premium 12软件。安装完成后,打开软件并在登录界面选择需要连接的数据库类型,并输入相应的连接信息,如服务器地址、端口、用户名和密码。点击连接按钮后,将会成功连接到数据库。 Navicat Premium 12提供了丰富的功能,例如数据浏览和编辑、SQL查询和脚本、数据备份和还原、数据库同步等。您可以通过简单的拖放操作,在数据库之间移动数据和字段,轻松实现数据的浏览和编辑。 另外,Navicat Premium 12还支持SQL查询和脚本,您可以使用SQL语句对数据库进行高级操作,如查询、插入、更新和删除数据等。同时,您还可以保存常用的查询和脚本作为模板,以便后续使用。 此外,Navicat Premium 12还提供了数据备份和还原的功能,您可以定期对数据库进行备份,以防止数据丢失。同时,您还可以使用导入和导出功能将数据库数据导入到其他应用程序或导出为常见的数据格式,如CSV、Excel等。 最后,Navicat Premium 12还支持数据库之间的同步操作,您可以将数据从一个数据库同步到另一个数据库,以确保数据的一致性和完整性。 综上所述,Navicat Premium 12是一款功能强大、使用简便的数据库管理工具,通过使用它,您可以方便地连接、浏览、编辑和操作数据库,提高工作效率。无论是数据库开发人员还是管理员,Navicat Premium 12都是一个非常实用的工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值