mysql将查询结果插入新表
来源:互联网 发布:kmp算法next作用 编辑:程序博客网 时间:2024/05/12 05:41
如何在mysql从多个表中组合字段然后插入到一个新表中,通过一条sql语句实现。具体情形是:有三张表a、b、c,现在需要从表b和表c中分别查几个字段的值插入到表a中对应的字段。对于这种情况,我们可以使用如下的语句来实现:
1. INSERT INTO db1_name(field1,field2) SELECT field1,field2 FROM db2_name
当然,上面的语句比较适合两个表的数据互插,如果多个表就不适应了。对于多个表,我们可以先将需要查询的字段join起来,然后组成一个视图后再select from就可以了:
1. 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的形式来组合字段。需要注意的是嵌套查询部分最后一定要有设置表别名,如下:
1. SELECT * FROM(SELECT f1,f2 FROM b JOIN c) AS tb
即最后的as tb是必须的(当然tb这个名称可以随意取),即指定一个别名,否则在mysql中会报如下错误:
1. ERROR 1248 (42000): Every derived TABLE must have its own alias
即每个派生出来的新表都必须指定别名才可以的。
在MySql4.0.12中,用" create table bak_name as select * from original_name"语句后,生成的bak 表没有主键及索引的,用到的时候一点要注意.可以先建一个和要备份的表结构一样的表back_name,用以下方法倒入数据
insert into bak_table select * from original_name 这个方法
- mysql将查询结果插入新表
- MySQL 数据库操作,将查询结果插入新表
- mysql 将查询结果插入一张表
- mysql 将查询结果插入一张表
- mysql创建临时表,将查询结果插入已有表中
- mysql 将查询结果插入一张表
- MySql将查询结果插入到另外一张表
- mysql学习- 将查询结果加上其他键值插入到表中
- MySQL将查询结果插入到数据表中
- MySQL将查询结果插入到数据表中
- MySQL将查询结果插入到数据表中
- MySQL将查询结果插入到数据表中
- MySQL将查询结果插入到数据表中
- mysql 将查询结果导入表中
- MySQL,查询其他表,插入新表
- 将查询结果插入到现有表中
- 将查询结果插入到现有表中
- 使用insert子句将查询结果插入到hive表
- mysql结果垂直显示
- mysql节省时间的命令
- MySQL数据库设计原则
- MYSQL 设计数据结构注意事项
- Oracle分区表
- mysql将查询结果插入新表
- linux用户管理命令
- Redhat5.2yum源更新为centos源
- Oracle11gExp导出空表方法
- MSSQLServer将远端数据库保存到本地
- 海康威视DS-4100、4000HC 系列板卡SDK编程指南
- Microsoft.ACE.OLEDB.12.0问题解决方法
- SQL Server 跨数据库查询
- 将Excel2007导入SQL Server2008操作方法