Sqlcmd
最新版本的 sqlcmd 工具
https://docs.microsoft.com/zh-cn/sql/tools/sqlcmd-utility?view=sql-server-ver15
sqlcmd 会话模式
在命令提示符下键入 sqlcmd,按 Enter
现在,您已与计算机上运行的默认 SQL Server 实例建立了可信连接
1> 是 sqlcmd 提示符,可以指定行号,每按一次 Enter,该数字就会加 1
若要结束 sqlcmd 会话,请在 sqlcmd 提示符中键入 EXIT
查看版本信息
sqlcmd -?
查看帮助信息
sqlcmd -?
sqlcmd -S localhost -U sa -P '123456';
登录并指定数据库
sqlcmd -S localhost\sqlserver_name -d database_name
执行SQL文件
执行脚本文件
sqlcmd -S localhost -U sa -P '123456' -i "G:\test.sql";
执行脚本文件并设置输出到指定文件
sqlcmd -S localhost -U sa -P '123456' -i "G:\t.sql" -o "G:\t2.txt";
注意:这里的路径要使用反斜线。
执行SQL字符串
sqlcmd -S localhost\sqlserver_name -d database_name
-Q "SELECT * FROM [table_name]"
SQL Server 数据库管理
连接SQL Server LocalDB
sqlcmd -S "(localdb)\MSSQLLocalDB"
查看数据库基本信息
use master
exec sp_helpdb [PandaTest]
查看所有数据库
use master
exec sp_helpdb
查看数据库中的所有对象
USE [PandaTest]
EXEC sp_help
查询数据文件或日志文件当前存放路径
注意:先要进入指定的数据库
SELECT physical_name FROM sys.database_files
获取数据库的逻辑名和日志逻辑名
注意:先要进入指定的数据库
select file_name(1),file_name(2)
SELECT name FROM sys.database_files
修改数据的逻辑名或者日志逻辑名
ALTER DATABASE [database_name] MODIFY FILE ( NAME = database_name, NEWNAME = new_database_name )
ALTER DATABASE [database_name] MODIFY FILE ( NAME = database_nameb_log, NEWNAME = new_database_name_log )
SQL Server 表管理
查看指定的表详细信息
USE [PandaTest]
EXEC sp_help [PandaTable]
SQL Server 账户管理
创建登录账户
CREATE LOGIN catalog_srv WITH PASSWORD = 'P@ssw0rd';
SQL Server 用户管理
CREATE USER user_name;
为用户增加角色
EXEC sp_addrolemember N'db_owner', N'username';
SQL Server 备份和恢复
备份数据库
backup database database_name to disk='E:\backup\database_name.bak'
恢复数据库
restore database database_name from disk='D:\backup\database_name.bak'
move 'database_name' to 'D:\Program Files\Microsoft SQL Server\MSSQL11.SQLEXPRESS\MSSQL\DATA\database_name.mdf',
move 'database_name_log' to 'D:\Program Files\Microsoft SQL Server\MSSQL11.SQLEXPRESS\MSSQL\DATA\database_name_log.ldf'
恢复数据库并修改数据库的名称
restore database update_database_name from disk='E:\backup\database_name.bak'
bcp 命令
bcp MDataPort.dbo.Recording out E:\Backup\recording.bcp -S .\sqlexpress -T -c
指定时间戳
bcp "select * from MDataPort.dbo.Recording where Timestamp >= '2019-02-01 00:00:00'" queryout E:\Backup\recording_20190201.bcp -S .\sqlexpress -T -c
bcp "select Timestamp from MDataPort.dbo.Recording" queryout E:\Backup\recording_Timestamp.bcp -S .\sqlexpress -T -c
导入整张表
bcp MDataPort.dbo.Recording in E:\Backup\recording.bcp -S .\sqlexpress -T -c