加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – SQLCMD的返回值

发布时间:2020-12-12 16:47:22 所属栏目:MsSql教程 来源:网络整理
导读:我需要检查通过SQLCMD实用程序运行的查询的退出状态(成功/失败).例如,我正在连接的服务器没有数据库名称EastWind.然后,以下命令失败,并显示消息… "C:Program FilesMicrosoft SQL Server100ToolsBinnSQLCMD.EXE" -S ZEPHIR -E -Q "USE WestWind"Changed
我需要检查通过SQLCMD实用程序运行的查询的退出状态(成功/失败).例如,我正在连接的服务器没有数据库名称EastWind.然后,以下命令失败,并显示消息…
> "C:Program FilesMicrosoft SQL Server100ToolsBinnSQLCMD.EXE" 
     -S ZEPHIR -E -Q "USE WestWind"
Changed database context to 'WestWind'.
> echo %errorlevel%
0
> "C:Program FilesMicrosoft SQL Server100ToolsBinnSQLCMD.EXE" 
     -S ZEPHIR -E -Q "USE EastWind"
Database 'EastWind' does not exist. Make sure that the name is entered correctly
> echo %errorlevel%
0

我看到这两种情况下的返回值是一样的.如何在SQLCMD中检查命令是否失败?

解决方法

你需要使用 -V option.

例:

> SQLCMD.EXE -S whatever -E -V16 -Q "USE does_not_exist"
  Msg 911,Level 16,State 1,...
  Could not locate entry ...
  > echo %ERRORLEVEL%
  16

更新:或者,您也可以使用-b选项.其具有不同的语义到执行(整个批次停止在第一个错误).因人而异.

例:

> SQLCMD.EXE -S whatever -E -b -Q "USE does_not_exist"
  Msg 911,...
  Could not locate entry ...
  > echo %ERRORLEVEL%
  1

您也可以组合-b和-V.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读