文档章节

MySQL中insert into select from的使用

郑加威
 郑加威
发布于 2017/08/18 16:30
字数 558
阅读 25
收藏 1

如何在MySQL从多个表中组合字段然后插入到一个新表中,通过一条sql语句实现。具体情形是:有三张表a、b、c,现在需要从表b和表c中分别查几个字段的值插入到表a中对应的字段。对于这种情况,我们可以使用如下的语句来实现:

INSERT INTO db1_name(field1,field2) SELECT field1,field2 FROM db2_name

      当然,上面的语句比较适合两个表的数据互插,如果多个表就不适应了。对于多个表,我们可以先将需要查询的字段join起来,然后组成一个视图后再select from就可以了:

INSERT INTO a(field1,field2) SELECT * FROM(SELECT f1,f2 FROM b JOIN c) AS tb

      其中f1是表b的字段,f2是表c的字段,通过join查询就将分别来自表b和表c的字段进行了组合,然后再通过select嵌套查询插入到表a中,这样就满足了我们这个场景了,如果需要不止2个表,那么可以多个join的形式来组合字段。需要注意的是嵌套查询部分最后一定要有设置表别名,如下:

SELECT * FROM(SELECT f1,f2 FROM b JOIN c) AS tb

      即最后的as tb是必须的(当然tb这个名称可以随意取),即指定一个别名,否则在mysql中会报如下错误:

ERROR 1248 (42000): Every derived TABLE must have its own alias

      即每个派生出来的新表都必须指定别名才可以的。

insert into inf_monitor_data
  (ID,
   IT_Catalog,
   IT_Function,
   Business_Name,
   Control_Adderss,
   Title,
   Detail,
   Start_Time,
   End_Time,
   BSM_Type,
   Status,
   Remarks)
  select i.P_Guid,
         case c.DE_ITCatalog
           when 1 then
            '应用'
           when 2 then
            '主机系统'
           when 3 then
            '主机硬件'
           when 4 then
            '网络设备'
           when 6 then
            '存储'
           else
            '其他'
         end,
         case c.DE_ITFunction
           when 101 then
            '网站'
           when 105 then
            '数据库'
           when 106 then
            '中间件'
           when 107 then
            'Web Server'
           when 201 then
            '服务器'
           when 402 then
            '交换机'
           when 403 then
            '防火墙'
           when 404 then
            '负载均衡'
           when 412 then
            '入侵防护'
           else
            '其他'
         end,
         c.D_BusinessName,
         c.D_ControlAdderss,
         i.D_Title,
         i.D_Detail,
         i.D_StartTime,
         i.D_EndTime,
         case i.AE_BSMType
           when 0 then
            'CI'
           when 1 then
            '可用性'
           when 2 then
            '容量'
           when 3 then
            '财务'
           else
            '其他'
         end,
         '0',
         ''
    from i_incident i
    Left outer join c_itcomp c
      on i.AF_SourceITCompId = c.P_Guid;

--END--

© 著作权归作者所有

共有 人打赏支持
郑加威
粉丝 110
博文 333
码字总数 626647
作品 0
杭州
架构师
私信 提问
php数据库之mysql connect create insert select

免费的 MySQL 数据库通常是通过 PHP 来使用的。 连接到一个 MySQL 数据库 在您能够访问并处理数据库中的数据之前,您必须创建到达数据库的连接。 在 PHP 中,这个任务通过 mysql_connect() ...

wbf961127
2017/11/12
0
0
mysql LAST_INSERT_ID详解

LASTINSERTID() LASTINSERTID(expr) 自动返回最后一个INSERT或 UPDATE 问询为 AUTO_INCREMENT列设置的第一个 发生的值。 mysql> SELECT LASTINSERTID(); -> 195 产生的ID 每次连接后保存在服...

刘德生
2013/09/11
0
0
last_insert_id()获取mysql最后一条记录ID

lastinsertid()自动返回最后一个INSERT或 UPDATE 查询中 AUTO_INCREMENT列设置的第一个表发生的值。 MySQL的LASTINSERTID的注意事项: 第一、查询和插入所使用的Connection对象必须是同一个才...

技术小胖子
2017/11/01
0
0
mysql 赋权细节!!

MySQL 赋予用户权限命令 本文实例,运行于 MySQL 5.0 及以上版本。 MySQL 赋予用户权限命令的简单格式可概括为:grant 权限 on 数据库对象 to 用户一、grant 普通数据用户,查询、插入、更新...

tiger2013
2014/04/16
0
0
转: MySQL 赋予用户权限(grant %-远程和localhost-本地区别)

相关参考资料: MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一、grant 普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。 grant select...

文文1
2015/03/23
0
0

没有更多内容

加载失败,请刷新页面

加载更多

存储过程知识点收集

记录下,以后要常用的问题 1、获取刚刚插入数据产生的ID SCOPE_IDENTITY 返回当前作用域的插入后产生的一条ID @@IDENTITY 返回当前表的最后一条ID

轻轻的往前走
7分钟前
0
0
elixir keyword和map的区别

┌──────────────┬────────────┬───────────────────────┐ │ Keyword List │ Map/Struct │ HashDict (deprec...

wmzsonic
10分钟前
0
0
解决bootstrap-table-fixed-columns.js显示列与隐藏列按钮切换表格不对齐

<table class="table-striped table-hasthead nowrap" id="tableTest1" data-search="true" data-show-columns="true" data-fixed-columns="true" data-fixed-number="3"></table> 含有dat......

tianyawhl
12分钟前
0
0
ES6 系列之 defineProperty 与 proxy

摘要: ## 前言 我们或多或少都听过“数据绑定”这个词,“数据绑定”的关键在于监听数据的变化,可是对于这样一个对象:`var obj = {value: 1}`,我们该怎么知道 obj 发生了改变呢? ## def...

阿里云官方博客
18分钟前
0
0
美团点评携手 PingCAP 开启新一代数据库深度实践之旅

一、背景和现状 在美团,基于 MySQL 构建的传统关系型数据库服务已经难于支撑公司业务的爆发式增长,促使我们去探索更合理的数据存储方案和实践新的运维方式。随着近一两年来分布式数据库大放...

TiDB
18分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部