MySQL 实现将一个库表里面的数据实时更新到另一个库表里面

需求描述:MySQL 里面有很多的数据库,这些数据库里面都有同一种表结构的表 (tb_warn_log),这张表的数据是实时更新的,现在需要将这些表的数据全部实时更新到另一个库的另一张表 (tb_alarm_management) 里面。

数据库结构如下:

tb_warn_log 表结构如下:

tb_alarm_management 表结构如下:

MySQL 存储过程定时任务:

-- 存储过程创建
use mdm_common_db;
delimiter //
create procedure timing_import_proce()
begin
DECLARE result_code INTEGER DEFAULT 0; -- 定义返回结果并赋初值 0
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET result_code=1; -- 在执行过程中出任何异常设置 result_code 为 1
DECLARE CONTINUE HANDLER FOR NOT FOUND SET result_code = 2; -- 如果表中没有下一条数据则置为 2 START TRANSACTION; -- 开始事务 INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,10,' 上海 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 上海铁路局 ',' 杭州工务段 ',' 杭州钱塘江大桥 ','mdm_1_db' from mdm_1_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_1_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_1_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,6,' 郑州 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 郑州铁路局 ',' 洛阳工务段 ',' 洛阳邙山隧道 ','mdm_2_db' from mdm_2_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_2_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_2_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,21,' 麻城 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 武汉铁路局 ',' 麻城工务段 ',' 麻武线 K71' ,'mdm_3_db' from mdm_3_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_3_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_3_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,11,' 武汉 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 武汉铁路局 ',' 武汉桥工段 ',' 孝感大桥 京广线上行 1136+880','mdm_4_db' from mdm_4_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_4_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_4_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,14,' 广州 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 广州铁路局 ',' 怀化工务段 ',' 沪昆线 1592+130-160 上行 ','mdm_14_db' from mdm_14_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_14_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_14_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,11,' 武汉 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 武汉铁路局 ',' 荆门桥工段 ',' 宜万线 1296+120-300','mdm_15_db' from mdm_15_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_15_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_15_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,4,' 北京 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 北京铁路局 ',' 北京工务段 ',' 北京西站监测站 ','mdm_17_db' from mdm_17_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_17_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_17_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,51,' 青藏 (西宁)',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 青藏铁路局 ',' 西宁工务段 ',' 米拉湾隧道 ','mdm_18_db' from mdm_18_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_18_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_18_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,51,' 青藏 (西宁)',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 青藏铁路局 ',' 西宁工务段 ',' 付家寨三号隧道 ','mdm_19_db' from mdm_19_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_19_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_19_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,12,' 长沙 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 广州铁路局 ',' 长沙高铁工务段 ',' 艾家冲隧道 ','mdm_21_db' from mdm_21_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_21_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_21_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,10,' 上海 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 上海铁路局 ',' 杭州工务段 ',' 杭州铁路宏远 ', 'mdm_55_db' from mdm_55_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_55_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_55_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,21,' 麻城 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 武汉铁路局 ',' 麻城工务段 ',' 武汉局麻城工务段试点项目 ','mdm_64_db' from mdm_64_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_64_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_64_db');
INSERT INTO mdm_common_db.tb_alarm_management(key_name,warn_type,warn_level,alarm_time,alarm_cityId,alarm_cityName,alarm_user,state,ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,TLJ,GWD,JCZ,GWDDatabase) SELECT SensorType,WarnMainType,WarnLevel,Time,11,' 武汉 ',DealName,' 未处理 ',ID,SensorID,WarnChildType,SendMessage,SendFlag,Dealed,DealPhone,Note,' 武汉铁路局 ',' 武汉桥工段 ',' 武汉桥工段铁路桥试点项目 ','mdm_65_db' from mdm_65_db.tb_warn_log WHERE not exists (select * from mdm_common_db.tb_alarm_management where mdm_common_db.tb_alarm_management.ID = mdm_65_db.tb_warn_log.ID AND mdm_common_db.tb_alarm_management.GWDDatabase = 'mdm_65_db'); IF result_code = 1 THEN -- 可以根据不同的业务逻辑错误返回不同的 result_code,这里只定义了 1 和 0
ROLLBACK;
ELSE
COMMIT;
END IF;
select result_code;
end//
delimiter ; -- 定时任务创建
create event timing_import_event
on schedule every 30 minute -- 每隔 30 分钟执行一次存储过程
on completion preserve disable
do call timing_import_proce(); -- 定时任务开启
alter event timing_import_event on completion preserve enable; -- 开启定时任务 -- 求和
select
(select count(*) from mdm_1_db.tb_warn_log)
+(select count(*) from mdm_2_db.tb_warn_log)
+(select count(*) from mdm_3_db.tb_warn_log)
+(select count(*) from mdm_4_db.tb_warn_log)
+(select count(*) from mdm_14_db.tb_warn_log)
+(select count(*) from mdm_15_db.tb_warn_log)
+(select count(*) from mdm_17_db.tb_warn_log)
+(select count(*) from mdm_18_db.tb_warn_log)
+(select count(*) from mdm_19_db.tb_warn_log)
+(select count(*) from mdm_21_db.tb_warn_log)
+(select count(*) from mdm_55_db.tb_warn_log)
+(select count(*) from mdm_64_db.tb_warn_log)
+(select count(*) from mdm_65_db.tb_warn_log) 求和; select count(*) from mdm_common_db.tb_alarm_management;

MySQL 实现将一个库表里面的数据实时更新到另一个库表里面的更多相关文章

  1. 使用php+swoole对client数据实时更新(下)

    上一篇提到了swoole的基本使用,现在通过几行基本的语句来实现比较复杂的逻辑操作: 先说一下业务场景.我们目前的大多数应用都是以服务端+接口+客户端的方式去协调工作的,这样的好处在于不论是处在何种终 ...

  2. 使用php+swoole对client数据实时更新(二) (转)

    上一篇提到了swoole的基本使用,现在通过几行基本的语句来实现比较复杂的逻辑操作: 先说一下业务场景.我们目前的大多数应用都是以服务端+接口+客户端的方式去协调工作的,这样的好处在于不论是处在何种终 ...

  3. oracle 批量更新之将一个表的数据批量更新至另一个表

      oracle 批量更新之将一个表的数据批量更新至另一个表 CreationTime--2018年7月3日17点38分 Author:Marydon Oracle 将一个表的指定字段的值更新至另一个 ...

  4. Excel 2010 如何将筛选后的数据复制粘贴到另一个工作表筛选后的表格里

    如果你是指自动筛选后,把筛选数据复制/粘贴到另外一个工作表中,不妨试试试 第一步选中筛选后的数据区域:第二步执行菜单命令“编辑/定位/定位条件/可见单元格”,确定:第三步单击复制按钮或者Ctrl+C或 ...

  5. mysql插入一张表里的数据到另一张表

    公司的一个项目,做报表--要关联的表结构比较多,最后决定把要用的数据集合到一张新表中,需要用到以下的sql语法......分享下: web开发中,我们经常需要将一个表的数据插入到另外一个表,有时还需要 ...

  6. Sqlite插入、修改、删除表里面的数据

    转载 2014年05月10日 10:38:21 标签: sqlite3 / 数据库 8688 转自:http://www.cnblogs.com/myqiao/archive/2011/07/13/2 ...

  7. 使用php+swoole对client数据实时更新(上)

    如果想对一个列表做实时的更新,传统的做法是采用轮询的方式.以web为例,通过Ajax定时请求服务端然后获取数据显示在页面.这种方式实现简单,缺点就是浪费资源. HTTP1.1新增加了对websocke ...

  8. 基于server broker 的数据实时更新

    Service Broker介绍:SQL Server Service Broker 为消息和队列应用程序提供 SQL Server 数据库引擎本机支持.这使开发人员可以轻松地创建使用数据库引擎组件在 ...

  9. Web网站数据”实时”更新设计

    请注意这个实时打上了双引号,没有绝对的实时,只是时间的颗粒不一样罢了(1ms,1s,1m). 服务器数据有更新可以快速通知客户端.Web 基于取得模式,而服务器建立大量的和客户端连接来提供数据实时更新 ...

随机推荐

  1. 使用 Sixel 图形格式在终端中显示缩略图

    不久前,我们讨论了 Fim,这是一个轻量级的命令行图像查看器应用程序,用于从命令行显示各种类型的图像,如 bmp.gif.jpeg 和 png 等.今天,我偶然发现了一个名为 lsix的类似工具.它类 ...

  2. CentOS服务器配置SSH免密码登录

    由于工作需要,经常要登录到多台服务器远程操作,每次都是ssh user@host:port 再输入密码,时间长了,难免觉得乏味-- 故而从度娘那里扒来了一些让SSH免密码登录的办法,其实这也是使用Gi ...

  3. stm32 外设使用的配置步骤

    @2018-5-10  使用外设的配置步骤 #1 打开时钟 > 打开外设时钟 > 打开相关GPIO时钟 > 打开DMA时钟  (若需要) #2 关联外设与GPIO > 复位关联 ...

  4. 生成器 yield

    由于生成器的其中一种创建方式与列表推导式很相似,这里先说一下列表推导式. 列表推导式 列表推导式又叫列表生成式,官方叫做 list comprehension.顾名思义,这个是用来生成列表的. 用法: ...

  5. WEB入门之十一 JS面向对象

    学习内容 JavaScript类的定义模式 JavaScript继承的实现 JavaScript抽象类 JavaScript解析XML 能力目标 深入了解JavaScript类的定义模式 理解Java ...

  6. list All elements are null引起的异常

    ArrayList允许添加null值,就容易造成了list内的对象转换出现java.lang.NullPointerException异常. 场景: 数据库 select  min(id) as id ...

  7. 烦人的IE7、8,半透明滤镜(filter:alpha)失效、png半透明失效的解决办法

    在项目中的问题,之前用的是用IETest测试IE7,8发现背景透明设置无效,后来找文章解决!看了一些资料,做下总结. 几种IE半透明CSS样式 IE8里可以这样写 -ms-filter:”progid ...

  8. 小议 html 实体解析

    今天分享个小技巧,是群里一个朋友问的,"请问 + 这种类型的字符串怎么转换成我们想要的字符 + ,有什么简便的js方法吗"其实问题说简单也简单,说难也难.我们要分情况来描述问题解决 ...

  9. 格式化 SQL 来提高效率

    本文由 伯乐在线 - cucr 翻译,黄利民 校稿.未经许可,禁止转载!英文出处:msiman.ga.欢迎加入翻译小组. 背景 已格式化的SQL并不比未格式化SQL运行地更快.数据库可能真的不太在意你 ...

  10. 蓝桥杯 问题 1117: K-进制数 (递归)

    题目链接 题目描述 考虑包含N位数字的K-进制数. 定义一个数有效, 如果其K-进制表示不包含两连续的0. 考虑包含N位数字的K-进制数. 定义一个数有效, 如果其K-进制表示不包含两连续的0. 例: ...