MSSQL-Scripter,一个新的生成T-SQL脚本的SQL Server命令行工具

这里向大家介绍一个新的生成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.   Windows

a)       安装Python,最新安装包下载地址:https://www.python.org/downloads/,注意安装的时候要选择”Add Python to PATH”选项:

b)      安装mssql-scripter,命令行里执行下面命令:

pip install mssql-scripter

2.   Linux

a)      检查pip版本,是否是9.0及其以上:

pip –version

b)      如果pip未安装或者版本低于9.0,使用如下命令安装以及升级版本:

sudo apt-get install python-pipsudo pip install --upgrade pip

c)      安装mssql-scripter:

sudo pip install mssql-scripter

如果系统是Ubuntu或者Debian,需要安装libunwind8软件包:

Ubuntu 14 & 17

执行如下命令:

sudo apt-get updatesudo apt-get install libunwind8

Debian 8(暂时没有环境,未测试)

文件‘/etc/apt/sources.list’需要更新:

deb http://ftp.us.debian.org/debian/ jessie main

执行如下命令:

sudo apt-get updatesudo apt-get install libunwind8

3.   macOS(暂时没有环境,未测试)

a)       检查pip版本,是否是9.0及其以上:

pip –version

b)      如果pip未安装或者版本低于9.0,使用如下命令安装以及升级版本:

sudo apt-get install python-pipsudo 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


相关例子:

下面这个是Linux和macOS的用法。

  • Script data to a file


更详细的Usage Guide或更新请参考:https://github.com/Microsoft/sql-xplat-cli/blob/dev/doc/usage_guide.md。

 

下面执行一个命令看看效果,生成SharePoint Translation Service DatabaseCREATE语句:


执行结果的文件可以在这里下载:http://files.cnblogs.com/files/lavender000/CreateTranslationServiceDatabase.zip。


另外还可以把连接字符串设置成环境变量:

# set environment variable MSSQL_SCRIPTER_CONNECTION_STRING with a connection string.

export MSSQL_SCRIPTER_CONNECTION_STRING='Server=myserver;Database=mydb;User Id=myuser;Password=mypassword;'

mssql-scripter 


# set environment variable MSSQL_SCRIPTER_PASSWORD so no password input is required.

export MSSQL_SCRIPTER_PASSWORD='ABC123'

mssql-scripter -S localhost -d AdventureWorks -U sa

原文地址:http://www.cnblogs.com/lavender000/p/6886560.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325482.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用startSmoothScroll实现RecyclerView滚动到指定位置并置顶,含有动画。

RecyclerView滚动到指定位置并置顶 RecyclerView本身提供了几个定位的方法,除了手动滑动的scrollTo,smootScrollTo和scrollBy,smoothScrollBy方法之外,有一个直接滑动到指定位置item的scrollToPosition方法和另一个在此基础上平滑…

跟我学 Java 8 新特性之 Stream 流(七)流与迭代器,流系列大结局

转载自 跟我学 Java 8 新特性之 Stream 流(七)流与迭代器,流系列大结局 恭喜你们,马上就要学完Java8 Stream流的一整系列了,其实我相信Stream流对很多使用Java的同学来说,都是一个知识盲点,因…

重要说明,粉丝必看【java人脸识别说明】

重要通知关于人脸识别简要说明: 源码即日起由免费改为收费。以下是微信收款码,如果有需要可以直接扫码转账即可。(注意,源码均为测试好的,故各位在开发的过程中遇到的源码问题不提供任何技术支持。【转账完成之后可以直…

包装类

如果用包装类可以打印出来 <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title></title><script type"text/javascript">var s123;snew String(s);s.hello"nihao";console.log(s.hello);<…

深入理解C#:编程技巧总结(二)

以下总结参阅了&#xff1a;MSDN文档、《C#高级编程》、《C#本质论》、前辈们的博客等资料&#xff0c;如有不正确的地方&#xff0c;请帮忙及时指出&#xff01;以免误导&#xff01; 在上一篇 深入理解C#&#xff1a;编程技巧总结&#xff08;一&#xff09; 中总结了25点&a…

pagerslidingtabstrip 横向滑动

pagerslidingtabstrip 横向滑动 配合ViewPager

Java 虚拟机对锁优化所做的努力

转载自 Java 虚拟机对锁优化所做的努力 作为一款公用平台&#xff0c;JDK 本身也为并发程序的性能绞尽脑汁&#xff0c;在 JDK 内部也想尽一切办法提供并发时的系统吞吐量。这里&#xff0c;我将向大家简单介绍几种 JDK 内部的 "锁" 优化策略。 1、 锁偏向 锁偏…

不一样的假期,到底哪里不一样?

目录&#xff1a;1.回访17级同学们&#xff0c;了解同学们目前的工作情况2.和18级同学们聊天&#xff0c;了解假期在家的学习情况3.检查19级同学们提交至小程序内的作业。回忆17级前两天将我带的17级毕业班挨个找了一遍&#xff0c;大致了解了下大家最近的工作情况&#xff0c;…

JS字符串和正则表达式

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title><script type"text/javascript">var str "1a2b3c4d5e6f7";/** split()* - 可以将一个字符串拆分为一个数组* - 方法中可以传递…

TensorFlowSharp入门使用C#编写TensorFlow人工智能应用

TensorFlowSharp入门使用C#编写TensorFlow人工智能应用学习。 TensorFlow简单介绍 TensorFlow 是谷歌的第二代机器学习系统&#xff0c;按照谷歌所说&#xff0c;在某些基准测试中&#xff0c;TensorFlow的表现比第一代的DistBelief快了2倍。 TensorFlow 内建深度学习的扩展支…

Mybatis 模糊查询

第一种&#xff1a;&#xff08;推荐&#xff09; select * from user where username like #{abc}执行保存操作List<User> users dao.findUserByName("保"); 日志&#xff1a;> Preparing: select * from user where username like %保%; > Parameter…

Spring Cloud 升级最新 Finchley 版本,踩了所有的坑

转载自 Spring Cloud 升级最新 Finchley 版本&#xff0c;踩了所有的坑 Spring Boot 2.x 已经发布了很久&#xff0c;现在 Spring Cloud 也发布了 基于 Spring Boot 2.x 的 Finchley 版本&#xff0c;现在一起为项目做一次整体框架升级。 升级前 > 升级后 Spring Boot …

快来看看你们的新年礼物,猜猜是什么?

春节总把新桃换旧符千门万户曈曈日春风送暖入屠苏爆竹声中一岁除新年礼物前言各位同学们&#xff0c;新春快乐哇&#xff0c;利用假期的时间&#xff0c;花费5天左右的时间&#xff0c;为大家每个人准备了一份神秘的新年礼物&#xff0c;想不想知道是什么吗&#xff1f;必看那么…

行动力决定了一个人的成败,有想法,就去做! C#的内存管理原理解析+标准Dispose模式的实现

尽管.NET运行库负责处理大部分内存管理工作&#xff0c;但C#程序员仍然必须理解内存管理的工作原理&#xff0c;了解如何高效地处理非托管的资源&#xff0c;才能在非常注重性能的系统中高效地处理内存。C#编程的一个优点就是程序员不必担心具体的内存管理&#xff0c;垃圾回收…

求从 1 到 100 之间所有奇数的平方和

public static void test15(){int i 1; //循环的初始值int sum 0;//放和的变量 while(i<100){if(i%2!0){sum sum(i*i); }i;}System.out.println("平方和是&#xff1a;"sum);}

让面试官颤抖的 HTTP 2.0 协议面试题

转载自 让面试官颤抖的 HTTP 2.0 协议面试题 Http协议&#xff0c;对于拥有丰富开发经验的程序员来说简直是信手拈来&#xff0c;家常便饭。虽然天天见&#xff0c;但是对于http协议的问题&#xff0c;可能很多人在没有积极准备的情况下&#xff0c;不一定能很好的回答出来。…

tomcat 实现 文件共享,查看文件目录

https://blog.csdn.net/qq_42922012/article/details/106682157

JS中闭包的应用自定义JS模块

/*** 自定义模块1*/ function coolModule() {//私有的数据var msg atguiguvar names [I, Love, you]//私有的操作数据的函数function doSomething() {console.log(msg.toUpperCase())}function doOtherthing() {console.log(names.join( ))}//向外暴露包含多个方法的对象retu…

一步步学习EF Core(3.EF Core2.0路线图)

前言 这几天一直在研究EF Core的官方文档,暂时没有发现什么比较新的和EF6.x差距比较大的东西.不过我倒是发现了EF Core的路线图更新了,下面我们就来看看 今天我们来看看最新的EF Core 2.0路线图 E文好的移步:https://github.com/aspnet/EntityFramework/wiki/Roadmap#ef-core…