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

背景:数据库

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

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

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

解决方案:blog

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

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

 

eg:配置

表studentselect

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

表数据:并行

如今要求插入几条数据,要求名字是从表中读取im

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

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

相关文章
相关标签/搜索