SQLServer知识:sqlcmd用法笔记

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: sqlcmd是一个 Microsoft Win32 命令提示实用工具,可以通过该命令工具实现SQL语句、脚本的执行,并且可以实现脚本任务的自动化。

今天给大家介绍sqlcmd用法笔记,希望对大家能有所帮助!

image_61df9ed6.png

1、介绍

sqlcmd是一个 Microsoft Win32 命令提示实用工具,可以通过该命令工具实现SQL语句、脚本的执行,并且可以实现脚本任务的自动化。

2、使用场景

2.1 针对大文件脚本的执行

脚本文件如果超过80兆,是不能够直接在查询编辑器执行的,会直接溢出报错,当然如果你的脚本文件超过几十兆,很有可能会造成SQLServer查询编辑器卡死、无响应。这个问题可以使用sqlcmd命令来解决。

2.2 确保系统部署的稳定、准确

我们在进行系统部署的时候,由于业务逻辑的调整,经常会有好几十个脚本文件需要执行,为了保证脚本执行不出差错,可以通过sqlcmd命令。来进行脚本文件到线上环境的部署。这样可以提高系统部署的质量、准确。

3、sqlcmd参数详解

3.1 语法格式

[{ { -U login\_id [ -P password ] } | –E trusted connection }]

[ -N encrypt connection ][ -C trust the server certificate ]

[ -z new password ] [ -Z new password and exit]

[ -S [protocol:]server[\instance\_name][,port] ] [ -H wksta\_name ] [ -d db\_name ]

[ -l login time\_out ] [ -A dedicated admin connection]

[ -i input\_file ] [ -o output\_file ]

[ -f < codepage > | i: < codepage > [ < , o: < codepage > ] ]

[ -u unicode output] [ -r [ 0 | 1 ] msgs to stderr ]

[ -R use client regional settings]

[ -q "cmdline query" ] [ -Q "cmdline query" and exit]

[ -e echo input ] [ -t query time\_out ]

[ -I enable Quoted Identifiers ]

[ -v var = "value"...] [ -x disable variable substitution ]

[ -h headers ][ -s col\_separator ] [ -w column\_width ]

[ -W remove trailing spaces ]

[ -k [ 1 | 2 ] remove[replace] control characters ]

[ -y display\_width ] [-Y display\_width ]

[ -b on error batch abort] [ -V severitylevel ] [ -m error\_level ]

[ -a packet\_size ][ -c cmd\_end ]

[ -L [ c ] list servers[clean output] ]

[ -p [ 1 ] print statistics[colon format]]

[ -X [ 1 ] ] disable commands, startup script, enviroment variables [and exit]

[ -? show syntax summary]

3.2 参数说明

登录相关选项

-A

使用专用管理员连接 (DAC) 登录 SQL Server。此类型连接用于排除服务器故障。此连接仅适用于支持 DAC 的服务器计算机。如果 DAC 不可用,sqlcmd 会生成错误消息并退出。-A 选项和-G 选项不支持同时使用。

-C

该开关供客户端用于将其配置为隐式表示信任服务器证书且无需验证。此选项等价于 ADO.NET 选项 trustservercertificate = true。

-d db\_name

启动 sqlcmd 时会发出一个 USE db\_name 语句用来指定要操作的数据库名称。此选项用来设置 sqlcmd 脚本变量 SQLCMDDBNAME。此参数指定初始数据库。默认为您的登录名的默认数据库属性。如果数据库不存在,则生成错误消息且 sqlcmd退出。

-l login\_timeout

指定在你尝试连接到服务器时 sqlcmd 登录 ODBC 驱动程序的超时时间(以秒为单位)。此选项设置 sqlcmd 脚本变量 SQLCMDLOGINTIMEOUT。登录到 sqlcmd 的默认超时时间为 8 秒。当使用 -G 选项连接到 SQL 数据库或 SQL 数据仓库并使用 Azure Active Directory 进行身份验证时,建议超时值至少为 30 秒。登录超时必须是介于 0 和 65534 之间的数字。如果提供的值不是数值或不在此范围内, sqlcmd 将生成错误消息。当值设置为 0 时,则允许无限制等待。

-E

使用信任连接而不是用户名和密码登录 SQL Server服务。默认情况下,如果未指定 -E , sqlcmd 将使用信任连接选项。

-E 选项会忽略可能的用户名和密码环境变量设置,例如 sqlcmdpassword。如果将 -E 选项与 -U 选项或 -P 选项一起使用,将生成错误消息。

-g

将列加密设置设为 Enabled。有关详细信息,请参阅 Always Encrypted。仅支持存储在 Windows 证书存储中的主密钥。-g 开关至少需要 sqlcmd 版本 13.1。若要确定你的版本,请执行 sqlcmd -?。

-G

当连接到 SQL 数据库或 SQL 数据仓库时,客户端将使用此开关指定该用户使用 Azure Active Directory 身份验证来进行身份验证。此选项设置 sqlcmd 脚本变量 SQLCMDUSEAAD = true。-G 开关至少需要 sqlcmd 版本 13.1。若要确定你的版本,请执行 sqlcmd -?。有关详细信息,请参阅 使用 Azure Active Directory 身份验证连接到 SQL 数据库或 SQL 数据仓库。-A 选项不支持使用-G 选项。

选项仅适用于 Azure SQL 数据库 和 Azure 数据仓库。

-H workstation\_name

工作站的名称。此选项设置 sqlcmd 脚本变量 SQLCMDWORKSTATION。工作站名称列出在 sys.sysprocesses 目录视图的 hostname 列中,并且可使用存储过程 sp\_who返回。如果不指定此选项,则默认为当前计算机名称。此名称可用来标识不同的 sqlcmd 会话。

-j 将原始错误消息输出到界面上。

-K application\_intent

连接到服务器时声明应用程序工作负荷类型。目前唯一支持的值是 ReadOnly。如果未指定 -K ,sqlcmd 实用工具将不支持连接到 AlwaysOn 可用性组中的次要副本。有关详细信息,请参阅活动次要副本:可读次要副本(AlwaysOn 可用性组)

-M multisubnet\_failover

在连接到 SQL Server 可用性组或 SQL Server 故障转移群集实例的可用性组侦听程序时,应始终指定 -M。-M 将为(当前)活动服务器提供更快的检测和连接。如果不指定 –M ,则 -M 处于关闭状态。有关详细信息 [!包括ssHADR,创建和配置的可用性组的(SQL Server),故障转移群集和 Alwayson 可用性组 (SQL Server),并活动次要副本:可读次要副本 (Alwayson 可用性组)。

-N

此开关供客户端用于请求加密连接。

-P password

用户指定的密码。密码是区分大小写的。如果使用了 -U 选项而未使用 -P 选项,并且未设置 SQLCMDPASSWORD 环境变量,则 sqlcmd 会提示用户输入密码。我们不建议使用 null 密码,但您可以通过连续双引号一对用于参数值指定 null 密码:

-P ""

建议使用强密码。

如果将 -P 选项与 -E 选项一起使用,将生成错误消息。

如果 -P 选项后有多个参数,将生成错误消息并退出程序。

-S [协议:]server[\instance\_name] [,* *端口]

指定要连接的 SQL Server 实例。它设置 sqlcmd 脚本变量 SQLCMDSERVER。

指定 server\_name 可连接到该服务器计算机上的 SQL Server 默认实例。指定要连接到该服务器计算机上 SQL Server 命名实例的 server\_name [ \instance\_name ]。如果不指定服务器,sqlcmd 将连接到本地计算机上 SQL Server 的默认实例。从网络上的远程计算机执行 sqlcmd 时,此选项是必需的。

-U login\_id

登录名或包含的数据库用户名。对于包含的数据库用户,必须提供数据库名称选项 (-d)。

-z new\_password

更改密码:

sqlcmd -U someuser -P s0mep@ssword -z a\_new\_p@a$$w0rd

-Z new\_password

更改密码并退出:

sqlcmd -U someuser -P s0mep@ssword -Z a\_new\_p@a$$w0rd

4、sqlcmd 示例说明

4.1 登录服务器

格式:sqlcmd -S 服务器名称 -U 帐户 -P 密码

示例:sqlcmd -S "127.0.0.1" -U "sa" -P "sa"

4.2 直接执行SQL脚本

格式:sqlcmd -S 服务器名称 -U 帐户 -P 密码 -d 数据库 -i SQL脚本

示例:sqlcmd -S "127.0.0.1" -U "sa" -P "sa" -d "MyDB" -i "D:\test.sql" --执行脚本文件

sqlcmd -S "127.0.0.1" -U "sa" -P "sa" -d "MyDB" -q "select * from UserInfo" -- 直接执行sql语句

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
8月前
|
SQL
sqlserver 常用操作
sqlserver 常用操作
|
SQL Oracle 关系型数据库
Oracle杂谈二 SQL*PLUS命令的使用大全
Oracle杂谈二 SQL*PLUS命令的使用大全
81 0
|
SQL 数据库
1 SQL快速入门、查询(SqlServer)[郝斌SqlServer完整版]
系统数据库:master、model、msdb、tempdb【我们自定义数据库的管理维护运行都需要系统库支持】
150 0
|
SQL 存储 数据库连接
SQLServer知识:sqlcmd用法笔记
sqlcmd是一个 Microsoft Win32 命令提示实用工具,可以通过该命令工具实现SQL语句、脚本的执行,并且可以实现脚本任务的自动化。
SQLServer知识:sqlcmd用法笔记
|
存储 SQL 数据库
SQLServer数据库文件相关知识笔记
数据库文件是SQLServer数据库的物理体现,和计算机的普通文件一样存储在计算机的磁盘空间当中。作为数据库记录和日志等其他信息的存储载体。
SQLServer数据库文件相关知识笔记
|
数据库
数据库:SQLServer Stuff 函数用法笔记
STUFF 函数将字符串插入到另一个字符串中。 它从第一个字符串的开始位置删除指定长度的字符;然后将第二个字符串插入到第一个字符串的开始位置。
数据库:SQLServer Stuff 函数用法笔记
|
存储 SQL 缓存
数据库:SQLServer中in和 exists函数用法笔记
今天给大家分享一下SQLServer中in和 exists 用法,希望能对大家有所帮助。
数据库:SQLServer中in和 exists函数用法笔记
|
SQL 数据库 索引
SQLServer优化:SQLServer中NOLOCK关键字的用法介绍
SQLServer没创建一个查询,都相当于创建一个查询会话,在不同的查询分析器里面进行的查询操作,可能会影响别的查询会话。比较典型的一个例子,如果你正在使用事务执行某一张表的插入或者操作而没有正确关闭事务的情况下,会造成别的会话针对该数据表的查
SQLServer优化:SQLServer中NOLOCK关键字的用法介绍
|
SQL XML 程序员
数据库:SQLServer中with as 用法笔记
with as 也叫做子查询部分(subquery factoring),可以定义一个SQL段落,该SQL段落可以被整个SQL语句所用到类似于临时表的作用。with as 可以提高你的SQL语句的可读性,也有可以用在在UNION ALL的不同部分,作为提供临时数据的部分。
数据库:SQLServer中with as 用法笔记
|
SQL 数据库 数据安全/隐私保护
(SQL)用bat启动sqlserver服务+创建数据库(学习笔记)(下)
我想创建一个bat的文本,于是就把记事本的后缀名txt直接改成了bat,但是当我想打开bat文件的时候却报错了。
(SQL)用bat启动sqlserver服务+创建数据库(学习笔记)(下)