我正在编写一个脚本,以在连接到 Azure SQL 数据仓库数据库的 Linux 上使用 SQLCMD 重新加载表。
INSERT 语句完成后,下一条语句失败(但不会结束 sqlcmd 执行)并显示“警告”
insert into
schema.table_temp
(
...list of columns
)
select
...list of columns
from
schema.table
;
GO(COMMENT--> 在脚本中,但未在日志中回显。)
(0 rows affected)
IF EXISTS (SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES t WHERE TABLE_TYPE = 'BASE TABLE' and TABLE_SCHEMA = 'schema' AND TABLE_NAME = 'table_nox' )
DROP TABLE schema.table_nox
;
GO(COMMENT--> 在脚本中,但未在日志中回显。)
SqlState 24000, Invalid cursor state
脚本继续运行,每个后续批次都获得相同的 SqlState 24000,游标状态无效“警告”
如果我注释掉 INSERT 语句,脚本会按预期运行而不会发出警告。我推测 INSERT 语句没有关闭游标,然后后续命令会收到警告,这应该被视为错误并结束执行。(我在 sqlcmd 调用中打开了 -b 标志。)
将脚本分成多个部分是我唯一的解决方案吗?