SQL INSERT及批量的几种方式总结

2023年 4月 14日 159.9k 0

目录 1、常规INSERT写法 2、SELECT语句返回值INSERT 3、批量多行INSERT 附:插入检索出的数据 总结 1、常规INSERT写法 INSERT INTO ...VALUES (...); INSERT INTO 表名( `字段1`, `字段2`) VALUES ('字段1的值'

目录1、常规INSERT写法2、SELECT语句返回值INSERT3、批量多行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批量方式内容请搜索每日运维以前的文章或继续浏览下面的相关文章希望大家以后多多支持每日运维!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论