首页 技术 正文
技术 2022年11月16日
0 收藏 968 点赞 4,810 浏览 768 个字

背景:

项目初期使用的配置库和业务库两种数据库并行,所有配置数据位于配置库,所有业务数据根据不同省份位于不同数据库。由于使用省份越来越多,各省的配置数据也越来越多导致配置库的数据量过于庞大,各省共用一个配置库数据,仅依靠省份编码去区分,查询一个简单配置数据需要耗费200ms。因此项目组提出配置库分离方案,将原有配置库数据拆分到各个省业务库中,由于代码中大部分会根据省份编码判断,因此业务库中的码表依旧需要省份编码字段。针对全网需求,如果涉及到配置数据,这样就需要提供31个省的数据脚本,这31个省的数据脚本可能仅仅只有省份编码不一样,这样的脚本会存在两个问题:

  1.脚本编写难度较大,耗费大量人力物力

  2.脚本执行难度较大,DBA 需要在31个省来回切数据库,执行对应脚本

解决方案:

  将31个省数据脚本编写为一个,所有脚本都一样,关于脚本中省份编码的数据根据库中数据来填充。

INSERT INTO TAB SELECT PROV_CODE,'固定值1','固定值2','固定值3' FROM TAB WHERE ...

eg:

表student

CREATE TABLE `student` (
`s_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'PRK',
`s_name` varchar(32) DEFAULT NULL COMMENT '学生姓名',
PRIMARY KEY (`s_id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8

表数据:

SQL插入数据–数据中的某一列来自本表中的数据

现在要求插入几条数据,要求名字是从表中读取

insert into student select 11,s_name from student where s_id = 8;

这里的 where 语句仅仅是为了限制查出来的结果这个可以根据实际情况编写。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,905
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,430
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,247
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,058
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,690
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,727