zoukankan      html  css  js  c++  java
  • SQL插入数据--数据中的某一列来自本表中的数据

    背景:

    项目初期使用的配置库和业务库两种数据库并行,所有配置数据位于配置库,所有业务数据根据不同省份位于不同数据库。由于使用省份越来越多,各省的配置数据也越来越多导致配置库的数据量过于庞大,各省共用一个配置库数据,仅依靠省份编码去区分,查询一个简单配置数据需要耗费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

    表数据:

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

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

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

  • 相关阅读:
    iphone开发之绘制地图线路
    (ios开发)在MapKit地图上添加注释
    IOS开发地图 (mapkit)实验
    iOS开发之在地图上绘制出你运行的轨迹
    iOS开发之在地图上绘制出你运动的轨迹
    iOS地图位置开发
    IOS开发中的数据库的学习
    Iphone开发 有关 Sqllist的用法
    MapKit
    iphone开发 有关 Navigation Bar 和 UITableView 的用法(代码加说明 呵呵)
  • 原文地址:https://www.cnblogs.com/zhaiyt/p/10469270.html
Copyright © 2011-2022 走看看