SQL插入多行

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL插入多行相关的知识,希望对你有一定的参考价值。

我想在一个表中插入多行。如何使用单个插入语句执行此操作?

答案

将要插入括号/括号(value1, value2, value3)的每一行值换行,并用逗号分隔括号/括号,以便插入到表中。

INSERT INTO example
VALUES
  (100, 'Name 1', 'Value 1', 'Other 1'),
  (101, 'Name 2', 'Value 2', 'Other 2'),
  (102, 'Name 3', 'Value 3', 'Other 3'),
  (103, 'Name 4', 'Value 4', 'Other 4');
另一答案

您可以使用SQL批量插入语句

BULK INSERT TableName
FROM 'filePath'
WITH
(
  FIELDTERMINATOR = '','',
  ROWTERMINATOR = ''
'',
  ROWS_PER_BATCH = 10000, 
  FIRSTROW = 2,
  TABLOCK
)

更多参考检查

https://www.google.co.in/webhp?sourceid=chrome-instant&ion=1&espv=2&ie=UTF-8#q=sql%20bulk%20insert

您也可以批量插入代码中的数据

请检查以下链接:

http://www.codeproject.com/Articles/439843/Handling-BULK-Data-insert-from-CSV-to-SQL-Server

另一答案
1--> {Simple Insertion when table column sequence is known}
    Insert into Table1
    values(1,2,...)

2--> {Simple insertion mention column}  
    Insert into Table1(col2,col4)
    values(1,2)

3--> {bulk insertion when num of selected collumns of a table(#table2) are equal to Insertion table(Table1) }   
    Insert into Table1 {Column sequence}
    Select * -- column sequence should be same.
       from #table2

4--> {bulk insertion when you want to insert only into desired column of a table(table1)}
    Insert into Table1 (Column1,Column2 ....Desired Column from Table1)  
    Select Column1,Column2..desired column from #table2
另一答案

你可以使用UNION ALL函数http://blog.sqlauthority.com/2007/06/08/sql-server-insert-multiple-records-using-one-insert-statement-use-of-union-all/

另一答案

您可以使用UNION All子句在表中执行多个插入。

例如:

INSERT INTO dbo.MyTable (ID, Name)
SELECT 123, 'Timmy'
UNION ALL
SELECT 124, 'Jonny'
UNION ALL
SELECT 125, 'Sally'

Check here

另一答案

对于MSSQL,有两种方法:(考虑您有'用户'表,下面两个示例都使用此表为例)

1)如果需要在users表中插入不同的值。然后你可以写如下语句:

    INSERT INTO USERS VALUES
(2, 'Michael', 'Blythe'),
(3, 'Linda', 'Mitchell'),
(4, 'Jillian', 'Carson'),
(5, 'Garrett', 'Vargas');

2)另一种情况,如果你需要为所有行插入相同的值(例如,你需要在这里插入10行)。然后你可以使用下面的示例声明:

    INSERT INTO USERS VALUES
(2, 'Michael', 'Blythe')
GO 10

希望这可以帮助。

以上是关于SQL插入多行的主要内容,如果未能解决你的问题,请参考以下文章

如何使用存储过程在 SQL 中插入多行?

SQL插入多行,但只执行一次子查询

带有 MySQL 的 NodeJS - 从数组中向 SQL 插入多行的最佳方法 [重复]

MS Access 中的多行插入语句

SQL插入多行

SQL插入多行,foreach