这里向大家介绍一个新的生成T-SQL脚本的SQL Server命令行工具:mssql-scripter。它支持在SQL Server、Azure SQL DB以及Azure SQL DW中为数据库生成CREATE和INSERT T-SQL脚本。
Mssql-scripter是一个跨平台的命令行工具,功能等同于SQL Server Management Studio中的Generate and Publish Scripts Wizard。
咱们能够在Linux、macOS和Windows上使用它生成数据定义语言(DDL-Data Definition Language)和数据操纵语言(DML – Data Manipulation Language),并且生成的T-SQL脚本可以运行在所有平台的SQL Server、Azure SQL Database、以及Azure SQL Data Warehouse中。
Installation 1. Windowsa) 安装Python,最新安装包下载地址:https://www.python.org/downloads/,注意安装的时候要选择”Add Python to PATH”选项:
b) 安装mssql-scripter,命令行里执行下面命令:
pip install mssql-scripter
2. Linuxa) 检查pip版本,是否是9.0及其以上:
pip –version
b) 如果pip未安装或者版本低于9.0,使用如下命令安装以及升级版本:
sudo apt-get install python-pip sudo pip install --upgrade pip
c) 安装mssql-scripter:
sudo pip install mssql-scripter
如果系统是Ubuntu或者Debian,需要安装libunwind8软件包:
Ubuntu 14 & 17执行如下命令:
sudo apt-get update sudo apt-get install libunwind8
Debian 8(暂时没有环境,未测试)文件‘/etc/apt/sources.list’需要更新:
deb http://ftp.us.debian.org/debian/ jessie main
执行如下命令:
sudo apt-get update sudo apt-get install libunwind8
3. macOS(暂时没有环境,未测试)a) 检查pip版本,是否是9.0及其以上:
pip –version
b) 如果pip未安装或者版本低于9.0,使用如下命令安装以及升级版本:
sudo apt-get install python-pip sudo pip install --upgrade pip
c) 安装mssql-scripter:
sudo pip install mssql-scripter
Usage Guide帮助命令:
mssql-scripter -h usage: mssql-scripter [-h] [--connection-string | -S ] [-d] [-U] [-P] [-f] [--data-only | --schema-and-data] [--script-create | --script-drop | --script-drop-create] [--target-server-version {2005,2008,2008R2,2012,2014,2016,vNext,AzureDB,AzureDW}] [--target-server-edition {Standard,PersonalExpress,Enterprise,Stretch}] [--include-objects [[...]]] [--exclude-objects [[...]]] [--ansi-padding] [--append] [--check-for-existence] [-r] [--convert-uddts] [--include-dependencies] [--headers] [--constraint-names] [--unsupported-statements] [--object-schema] [--bindings] [--collation] [--defaults] [--extended-properties] [--logins] [--object-permissions] [--owner] [--use-database] [--statistics] [--change-tracking] [--check-constraints] [--data-compressions] [--foreign-keys] [--full-text-indexes] [--indexes] [--primary-keys] [--triggers] [--unique-keys] [--display-progress] [--enable-toolsservice-logging] [--version] Microsoft SQL Server Scripter Command Line Tool. Version 1.0.0a1 optional arguments: -h, --help show this help message and exit --connection-string Connection string of database to script. If connection string and server are not supplied, defaults to value in Environment Variable MSSQL_SCRIPTER_CONNECTION_STRING. -S , --server Server name. -d , --database Database name. -U , --user Login ID for server. -P , --password Password. -f , --file Output file name. --data-only Generate scripts that contains data only. --schema-and-data Generate scripts that contain schema and data. --script-create Script object CREATE statements. --script-drop Script object DROP statements --script-drop-create Script object CREATE and DROP statements. --target-server-version {2005,2008,2008R2,2012,2014,2016,vNext,AzureDB,AzureDW} Script only features compatible with the specified SQL Version. --target-server-edition {Standard,PersonalExpress,Enterprise,Stretch} Script only features compatible with the specified SQL Server database edition. --include-objects [ [ ...]] Database objects to include in script. --exclude-objects [ [ ...]] Database objects to exclude from script. --ansi-padding Generates ANSI Padding statements. --append Append script to file. --check-for-existence Check for database object existence. -r, --continue-on-error Continue scripting on error. --convert-uddts Convert user-defined data types to base types. --include-dependencies Generate script for the dependent objects for each object scripted. --headers Include descriptive headers for each object scripted. --constraint-names Include system constraint names to enforce declarative referential integrity. --unsupported-statements Include statements in the script that are not supported on the target SQL Server Version. --object-schema Prefix object names with the object schema. --bindings Script options to set binding options. --collation Script the objects that use collation. --defaults Script the default values. --extended-properties Script the extended properties for each object scripted. --logins Script all logins available on the server, passwords will not be scripted. --object-permissions Generate object-level permissions. --owner Script owner for the objects. --use-database Generate USE DATABASE statement. --statistics Script all statistics. --change-tracking Script the change tracking information. --check-constraints Script the check constraints for each table or view scripted. --data-compressions Script the data compression information. --foreign-keys Script the foreign keys for each table scripted. --full-text-indexes Script the full-text indexes for each table or indexed view scripted. --indexes Script the indexes (XML and clustered) for each table or indexed view scripted. --primary-keys Script the primary keys for each table or view scripted. --triggers Script the triggers for each table or view scripted. --unique-keys Script the unique keys for each table or view scripted. --display-progress Display scripting progress. --enable-toolsservice-logging Enable verbose logging. --version show program's version number and exit
相关例子:
Dump database object schema