【Mysql数据同步】- A库多张不同表组合数据同步到B库的一张表中

原思路:
1、A库中多张表做聚合查询(结果应与B库中的表结构一致);
2、将其导出成insert语句;
3、修改insert语句冰在B库中执行;
缺点:
1、执行insert语句时需要改变表的名称;
2、查出的结果数据的字段名必须与要导入的表结构字段名一致,否则需要人工手动的去修改字段名;
3、导入时若字段属性不为空,出现null值时报执行异常;

新思路:
1、直接将查出来的结果用字符串拼接方法 CONCAT ,将其拼接成 INSERT 字符串,只能是成列,直接粘贴执行即可,具体SQL如下:

SELECT
	CONCAT(
		"INSERT INTO `channel_bill` (`id`, `apply_no`, `waybill_no`, `bill_type`, `title_type`, `title`, `taxpayer_no`, `email`, `content`, `total_amount`, `address`, `phone`, `bank_name`, `bank_no`, `user_code`, `memo`, `status`, `fail_reson`, `bill_code`, `bill_no`, `url`, `audit_status`, `billing_time`, `service_phone`, `is_delete`, `latest_time`, `record_version`, `created_by`, `creater_time`, `created`, `updated_by`, `updated`) VALUES (",
		IFNULL(i.item_id, ''),
		",'",
		IFNULL(i.apply_no, ''),
		"','",
		IFNULL(i.waybill_no, ''),
		"','",
		IFNULL(a.bill_type, ''),
		"','",
		IFNULL(a.title_type, ''),
		"','",
		IFNULL(a.title, ''),
		"','",
		IFNULL(a.taxpayer_no, ''),
		"','",
		IFNULL(a.email, ''),
		"','",
		IFNULL(a.content, ''),
		"','",
		IFNULL(i.total_amount, ''),
		"','",
		IFNULL(a.address, ''),
		"','",
		IFNULL(a.phone, ''),
		"','",
		IFNULL(a.bank_name, ''),
		"','",
		IFNULL(a.bank_no, ''),
		"','",
		IFNULL(a.user_code, ''),
		"','",
		IFNULL(a.memo, ''),
		"','",
		IFNULL(a. STATUS, ''),
		"','",
		IFNULL(a.failReson, ''),
		"','",
		IFNULL(a.bill_code, ''),
		"','",
		IFNULL(a.bill_no, ''),
		"','",
		IFNULL(a.url, ''),
		"','",
		IFNULL(a.audit_status, ''),
		"','",
		IFNULL(a.billing_time, ''),
		"','",
		IFNULL(a.service_phone, ''),
		"','",
		IFNULL(i.is_delete, ''),
		"','",
		IFNULL(i.latest_time, ''),
		"','",
		IFNULL(i.record_version, ''),
		"','",
		IFNULL(i.creater, ''),
		"','",
		IFNULL(i.creater_time, ''),
		"','",
		IFNULL(i.creater_time, ''),
		"','",
		IFNULL(i.modifier, ''),
		"','",
		IFNULL(i.modifier_time, ''),
		"');"
	)
FROM
	wechat_bill_item i
LEFT JOIN wechat_bill_apply a ON a.apply_no = i.apply_no;

执行结果如下:

 这样出来的insert语句就不需要认为的修改,在编写select语句的时候就能将其修改成自己想要的字段,很灵活;

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值