如何将多行插入 SQL 服务器并行数据仓库 table
How to insert multiple rows into SQL Server Parallel Data Warehouse table
我在 PDW AU5 上 SQL Server 2012 服务器。我有一个空的复制 table,我正在尝试将数据加载到其中。我只加载 2 条记录。所以,我在做:
INSERT INTO dbo.some_table
(Col1, Col2, Col3)
VALUES
(1, 'x', 'a'),
(2, 'y', 'b')
从网上的书上看,应该可以。 (它适用于 SMP。)但是,PDW 会抛出一条错误消息:Parse error at line: 4, column: x: Incorrect syntax near ','.
此错误所指的逗号是第一个元组之后的逗号。
我究竟做错了什么? AU5 不允许通过 INSERT INTO 插入多行吗?
MSDN 上 INSERT INTO
的文档指出并行数据仓库和 Azure SQL 数据仓库使用与正常 SQL 服务器相比不同的插入语法,后者根本不支持多个VALUES
不幸的是元组:https://msdn.microsoft.com/en-us/library/ms174335.aspx
-- Azure SQL Data Warehouse and Parallel Data Warehouse
INSERT INTO [ database_name . [ schema_name ] . | schema_name . ] table_name
[ ( column_name [ ,...n ] ) ]
{
VALUES ( { NULL | expression } [ ,...n ] )
| SELECT <select_criteria>
}
[ OPTION ( <query_option> [ ,...n ] ) ]
[;]
但是请注意,它确实支持 INSERT INTO [...] SELECT [..]
语法,因此您可以像这样破解它:
INSERT INTO foo ( x, y, z )
SELECT 1, 'x', 'a' UNION ALL
SELECT 2, 'y', 'b' UNION ALL
SELECT 3, 'z', 'c' UNION ALL
SELECT 4, 'a', 'd' UNION ALL
SELECT 5, 'b', 'e'
(最后一行没有UNION ALL
表达式)
使用 INSERT INTO 和 SELECT:如果要插入的行数非常多,它可能会失败并显示错误:
Msg 102042, Level 16, State 1, Line 1
The query processor ran out of stack space during query optimization. Please simplify the query.
我发现的唯一替代方法是按如下方式单独插入每一行:
create table #A (ID integer, CollA varchar(10), CollB Varchar(50))
Insert into #A values (2176035,'ADM1','DIFFERENT TO OPS1 APP')
Insert into #A values (5530921,'ADM7','DIFFERENT TO OPS1 APP')
Insert into #A values (5034949,'ADM7','DIFFERENT TO OPS1 APP')
Insert into #A values (3780563,'ADM4','DIFFERENT TO OPS1 APP')
Insert into #A values (5215169,'ADM2','DIFFERENT TO OPS1 APP')
我在 PDW AU5 上 SQL Server 2012 服务器。我有一个空的复制 table,我正在尝试将数据加载到其中。我只加载 2 条记录。所以,我在做:
INSERT INTO dbo.some_table
(Col1, Col2, Col3)
VALUES
(1, 'x', 'a'),
(2, 'y', 'b')
从网上的书上看,应该可以。 (它适用于 SMP。)但是,PDW 会抛出一条错误消息:Parse error at line: 4, column: x: Incorrect syntax near ','.
此错误所指的逗号是第一个元组之后的逗号。 我究竟做错了什么? AU5 不允许通过 INSERT INTO 插入多行吗?
MSDN 上 INSERT INTO
的文档指出并行数据仓库和 Azure SQL 数据仓库使用与正常 SQL 服务器相比不同的插入语法,后者根本不支持多个VALUES
不幸的是元组:https://msdn.microsoft.com/en-us/library/ms174335.aspx
-- Azure SQL Data Warehouse and Parallel Data Warehouse
INSERT INTO [ database_name . [ schema_name ] . | schema_name . ] table_name
[ ( column_name [ ,...n ] ) ]
{
VALUES ( { NULL | expression } [ ,...n ] )
| SELECT <select_criteria>
}
[ OPTION ( <query_option> [ ,...n ] ) ]
[;]
但是请注意,它确实支持 INSERT INTO [...] SELECT [..]
语法,因此您可以像这样破解它:
INSERT INTO foo ( x, y, z )
SELECT 1, 'x', 'a' UNION ALL
SELECT 2, 'y', 'b' UNION ALL
SELECT 3, 'z', 'c' UNION ALL
SELECT 4, 'a', 'd' UNION ALL
SELECT 5, 'b', 'e'
(最后一行没有UNION ALL
表达式)
使用 INSERT INTO 和 SELECT:如果要插入的行数非常多,它可能会失败并显示错误:
Msg 102042, Level 16, State 1, Line 1
The query processor ran out of stack space during query optimization. Please simplify the query.
我发现的唯一替代方法是按如下方式单独插入每一行:
create table #A (ID integer, CollA varchar(10), CollB Varchar(50))
Insert into #A values (2176035,'ADM1','DIFFERENT TO OPS1 APP')
Insert into #A values (5530921,'ADM7','DIFFERENT TO OPS1 APP')
Insert into #A values (5034949,'ADM7','DIFFERENT TO OPS1 APP')
Insert into #A values (3780563,'ADM4','DIFFERENT TO OPS1 APP')
Insert into #A values (5215169,'ADM2','DIFFERENT TO OPS1 APP')