mysql UNION的另类用法——一条SQL插入多条数据

UNION 操作符用于合并两个或多个 SELECT 语句的结果集。

需要注意的是:

1、UNION 内部的 SELECT 语句必须拥有相同数量的列;

2、列也必须拥有相同的数据类型;

3、每条 SELECT 语句中的列的顺序必须相同;

4、UNION 操作符默认选取不同的值。如果允许重复的值,请使用 UNION ALL;

以上是UNION的语法要求;

言归正传,怎样才能一条SQL插入多条数据呢?

场景1:直接添加多条记录

INSERT INTO (col1,col2,col3)
SELECT val1,val2,val3 UNION
SELECT val1,val2,val3 UNION
SELECT val1,val2,val3 UNION
SELECT val1,val2,val3 ;

场景2:从其他的多张表中读取数据添加到新表中 

INSERT tableName(col1,col2,col3)   
SELECT a,b,c FROM table1 WHERE a=1   
UNION ALL  
SELECT a,b,c FROM table2 WHERE a=2;  

// 数据来源于单表的话,那就不需要UNION了
INSERT tableName(col1,col2,col3)    
SELECT a,b,c FROM table2;

批量插入数据的话,建议可以使用UNION插入数据,效率更高,因为节约大部分数据库连接和关闭的时间,具体一次插入多少条更为合适,这需要取决于服务器实际环境;如果不想费劲的话,就一次插入10条得了,肯定比一条一条插入效率要高很多;

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值