2

我正在编写一个脚本,以在连接到 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 标志。)

将脚本分成多个部分是我唯一的解决方案吗?

4

3 回答 3

3

这似乎是 sqlcmd 在后台使用的 ODBC 驱动程序的问题。您能否确认您是否在 Azure SQL DB 中看到此问题?最好能看到您的 odbc.ini 和 odbcinst.ini 文件。你能把这些分享出来吗?

同时,我想推荐几个非常酷的 Node.js 命令行工具,它们更适合 Linux 和 Mac 环境:
SQL-CLI
Cheetah

谢谢,
遇见

于 2016-07-20T20:53:37.217 回答
0

我遇到了类似的问题,GO在两个语句之间添加对我有帮助。

于 2016-12-15T13:24:24.317 回答
0

我们有同样的问题。INSERT通过 a执行时,SELECT它会导致(0 rows affected)响应和invalid cursor state错误。SET NOCOUNT ON在脚本开头添加对我们有用。正如@meet-bhagdev 已经指出的那样,它看起来像是驱动程序问题。

于 2021-04-23T18:49:32.037 回答