SQL INSERT及批量的几种方式总结
1、常规INSERT写法
INSERT INTO ... VALUES (...);
INSERT INTO 表名( `字段1`, `字段2`) VALUES ('字段1的值', '字段2的值');
2、SELECT语句返回值INSERT
INSERT INTO ...VALUES (..., (select ...));
INSERT INTO 表名1(`字段1`, `字段2`)
VALUES (字段1的值, (select 查询字段 from 表名2 where 条件));
也可以变化为查询多个字段,再新增数据
INSERT INTO ...VALUES (select ...);
INSERT IGNORE INTO `表名1` ( `字段1`, `字段2` ) SELECT `字段3` AS 字段1, '字段4' AS 字段2 FROM `表名2` WHERE 条件
注意:查询出来必须只有一个行
3、批量多行INSERT
INSERT INTO ... VALUES (...), (...),(...);
INSERT INTO 表名(字段1, 字段2) VALUES (字段1数据, 字段2数据), (字段1数据, 字段2数据), (字段1数据, 字段2数据);
或者多行查询后新增,
INSERT INTO ... VALUES (...,select...), (...,select...),(...,select...);
INSERT INTO 表名1(`字段1`, `字段2`) VALUES (字段1的值, (select 查询字段 from 表名2 where 条件)), (字段1的值, (select 查询字段 from 表名3 where 条件)), (字段1的值, (select 查询字段 from 表名4 where 条件));
或者使用union all:
INSERT INTO ...
(SELECT ...,(select ...) ) union all
(SELECT ...,(select ...) ) union all
(SELECT ...,(select ...) );
INSERT INTO 表名1 (`字段1`, `字段2`) (SELECT 字段1的值,(select 查询字段 from 表名2 where 条件) FROM 表名3 WHERE 条件) union all (SELECT 字段1的值,(select 查询字段 from 表名2 where 条件) FROM 表名3 WHERE 条件) union all (SELECT 字段1的值,(select 查询字段 from 表名3 where 条件) FROM 表名4 WHERE 条件);
分享一下、日常使用到几种写法,如有错误,欢迎指正。
附:插入检索出的数据
INSERT INTO Customers(ID, name, address, city, country) SELECT ID, name, address, city, country from Custnew;
总结
到此这篇关于SQL INSERT及批量的几种方式的文章就介绍到这了,更多相关SQL INSERT批量方式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SQL NULL值的定义测试处理空数据及SQL UPDATE语句使用详解
这篇文章主要为大家介绍了SQL NULL值的定义测试处理空数据及SQL UPDATE语句使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11
最新评论