简介

在开发过程,我们常常会遇到数据库环境部署的问题,当部署正式环境中,数据库产生的多文件脚本在管理上就容易出现混乱,特别是你还没有权限访问正式环境的情况,就更为困难。SSDT为我们提供了很好的解决方案。

SSDT: Sql Server Data Tool,数据库工具,这里主要针对其作用于数据库版本控制的功能。

在VS中,SSDT主要添加了两项功能:SQL Server Database Project和DACPAC(Data-Tier Application Package)

简单介绍下DACPAC,DACPAC文件包含整个数据库的信息和SQL相关的查询数据。当部署新版本数据库到一个文件中时,DACPAC类似于备份功能,会将数据部署到每一张表中。

SQL Server DataBase Project

顾名思义,SSDP就是一个SQL数据库的项目。添加一个数据库项目,可以导入相关的数据库信息,如存储过程、试图等等。还可以拥有DACPAC文件,用于备份和版本控制功能。

如何添加?

1、在项目中添加SQL Server Database Project

2、将数据库导入到项目中

3、创建Data文件夹以及部署后执行的“PostDeployment”Sql脚本。创建后,SSDT还提供一系列的功能便于对比,如语法、数据对比等。

数据库的发布

SSDT提供多种发布部署的方法

  1. 如果你有权限可以通过VS直接连接SQL的,那么通过右键项目的“Publish”选项,即可以完成部署功能
  2. 如果你没有权限访问数据库,比如正式产品环境的数据库。这时候你就需要使用DACPAC进行部署

    首先先介绍下如果生成DACPAC文件,在数据库项目中,右键“Snapshot Project”,将会生成当前数据库的版本,存在于文件夹Snapshots下,如下图

    

    其次关于部署DACPAC方式也包含两种:

    a. 通过Sql Server 2012的Tasks里的Upgrade DACPAC功能实现

    

    b. 通过运行Code方式实现

    如果在MVC项目下,你可以将code写于Global.asax的Application_Start方法下,这里举例用新建Console Application的方式执行。

    

    在Proram下,我们添加入下代码

    1. 针对单个DACPAC文件部署到正式环境。

 class Program
{
static void Main(string[] args)
{
try
{
//1. 单个DACPAC文件的部署
const string ConnectionStringName = "Data Source=.;initial catalog=Template;Integrated Security=True;";//可以写到app.config中
var dacPackage = DacPackage.Load(ConnectionStringName);
var dacServices = new DacServices(ConnectionStringName);
var targetDatabaseName = (new SqlConnectionStringBuilder(ConnectionStringName)).InitialCatalog;
dacServices.Deploy(dacPackage, targetDatabaseName, true);
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
}
Console.WriteLine("<Press any key to exit.>");
Console.ReadKey();
}
}

    2. 针对Snapshots下多个DACPAC文件一键部署,则需要对比数据库快照的版本号,部署最新版本

//2. Snapshots文件夹下多个DACPAC文件的部署,通过遍历需要判断版本号部署
const string SnapshotFolder = "Snapshots";
foreach (var dacpacFileName in Directory.GetFiles(SnapshotFolder, "*.dacpac").OrderBy(name => name))
{
var databaseVersion = GetCurrentDacVersionFromDatabase(ConnectionStringName);
if (dacPackage.Version <= databaseVersion)
{
continue;
}
var dacDeployOptions = new DacDeployOptions { RegisterDataTierApplication = true };
dacServices.Deploy(dacPackage, targetDatabaseName, true, dacDeployOptions);
}

    需要一个方法来判断当前的版本号

private static Version GetCurrentDacVersionFromDatabase(string connectionString)
{
var returnValue = new Version();
const string SqlStatement = "SELECT TOP 1 type_version FROM msdb.dbo.sysdac_instances_internal WHERE instance_name = db_name()";
try
{
using (var connection = new SqlConnection(connectionString))
{
connection.Open();
using (var command = new SqlCommand(SqlStatement, connection))
{
using (var reader = command.ExecuteReader())
{
if (reader.Read())
{
var stringVersion = reader[].ToString();
Version.TryParse(stringVersion, out returnValue);
}
}
}
}
}
catch
{
}
return returnValue;
}

小结和注意事项

1、在做部署的时候,应记得在本地备份一个数据库

2、需要有文档,注释升级了哪些数据库内容

3、”Publish”用于可以连接数据库,DACPAC部署用于无权限连接数据库

4、在用Code部署DACPAC文件的时候,需要注意判断下版本号

5、SSDT的安装目录 C:\Program Files (x86)\Microsoft SQL Server\120\DAC\bin\

如果使用的是VS2012或者最低版本的VS,路径C:\Program Files (x86)\Microsoft SQL Server\110\DAC\bin\,因为SSDT最新版本为了避免与VS的目录发生冲突进而将安装目录放于120。

如何使用SSDT进行SQL数据库的自动化部署到生产环境和版本控制的更多相关文章

  1. Greenplum 数据库安装部署(生产环境)

    Greenplum 数据库安装部署(生产环境) 硬件配置: 16 台 IBM X3650, 节点配置:CPU 2 * 8core,内存 128GB,硬盘 16 * 900GB,万兆网卡. 万兆交换机. ...

  2. 转_Greenplum 数据库安装部署(生产环境)

    Greenplum 数据库安装部署(生产环境) 硬件配置: 16 台 IBM X3650, 节点配置:CPU 2 * 8core,内存 128GB,硬盘 16 * 900GB,万兆网卡. 万兆交换机. ...

  3. Jenkins+maven+gitlab自动化部署之基础环境部署(一)

    从一个二线城市,来到上海,刚入职,老大就给任务,为了减少开发打包部署时间,需要搭建一套自动化部署环境.接到任务后,赶紧上网查找资料,以及了解jenkins作用等等,用了一周时间,了解了个大概,由于都是 ...

  4. Headless MSBuild Support for SSDT (*.sqlproj) Projects [利用msbuild自动化部署 .sqlproj]- 摘自网络

    Update: breaking change: http://sqlproj.com/index.php/2012/10/dacfx-sept-2012-updates-break-headless ...

  5. CentOS 6.5环境使用ansible剧本自动化部署Corosync + pacemaker环境及corosync常用配置详解

    环境说明: 192.168.8.39 node2.chinasoft.com 192.168.8.42 node4.chinasoft.com 192.168.8.40 ansible管理服务器 19 ...

  6. My Sql数据库设置环境变量和字符集

    一.踩坑背景 之前开发中一直用的是sql  server 数据库,最近接到公司一个老的项目,用的my sql数据库做的,功能做了一大部分,现在客户要求对原程序和数据库进行服务器的迁移工作.产品经理给出 ...

  7. Asp.net Core 使用Jenkins + Dockor 实现持续集成、自动化部署(四):发布与回滚

    写在前面 我们以前windows跑.net Framework程序的时候,发布,自己乖乖的替换程序:备份,也是自己一个一个的重命名备份:回滚,发布遇到问题的回滚更是不用说了:运维很是怕我们 这些用wi ...

  8. 运维与自动化系列③自动化部署基础与shell脚本实现

    自动化部署基础与shell脚本实现 关于自动化的基础知识: 1.1:当前代码部署的实现方式: 运维纯手工scp到web服务器纯手工登录git服务器执行git pull或svn服务器执行svn upda ...

  9. 使用_Capistrano_进行自动化部署(2)

    之前的一篇文章是为了解决问题而写的,很多东西都没有介绍清楚,这一篇文章就是完整介绍一下 Capistrano,主要的参考来源是 Modern PHP 这本书. Capistrano 是用于自动部署应用 ...

随机推荐

  1. Hugo hexo 搭建博客系列1:自己的服务器

    hexo jekyll https://hexo.io/zh-cn/ http://theme-next.iissnan.com/getting-started.html Hexo 是高效的静态站点生 ...

  2. 使用GitBook, Git github, Markdown 快速发布你的书籍

    利用git作为版本管理和发布工具 你可以直接通过npm安装gitbook到全局 npm install -g gitbook gitbook只提供了如下四个命令 gitbook -h Usage: g ...

  3. php 生成8位数唯一的激活码

    /** *生成激活码 */ function showGenerationActivationCode(){ #渠道类型id $channel_id=$_POST['channel']; #根据渠道i ...

  4. XML5632 : Only one root element is allowed. Line: 1, Column 1

    奇葩啊, 最后查出来是因为有一个svg文件名对不上...

  5. CAShapeLayer实现圆形进度条效果

    一.CAShapeLayer简单介绍: .CAShapeLayer继承至CALayer,能够使用CALayer的全部属性值 2.CAShapeLayer须要与贝塞尔曲线配合使用才有意义 3.使用CAS ...

  6. TP框架---thinkphp表单验证

    自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证.验证的代码要写在模型层即Model里面. 数据验证有两种方式: 静态方式:在模型类里面 ...

  7. 九度OJ 1186:打印日期 (日期计算)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6366 解决:2214 题目描述: 给出年分m和一年中的第n天,算出第n天是几月几号. 输入: 输入包括两个整数y(1<=y<= ...

  8. every row of W is a classifier for one of the classes

    every row of W is a classifier for one of the classes As we saw above, every row of W is a classifie ...

  9. Java 重写 equals 与 hashCode 的注意事项

    为什么重写 equals 的时候必须重写 hashCode 大家可能从很多教程中了解到: SUN官方的文档中规定"如果重定义equals方法,就必须重定义hashCode方法,以便用户可以将 ...

  10. 学习使用MarkDown

    文本采用CuteMarkEd软件编写后复制到博客园(这个软件可以实时观看html效果,也可以打印pdf,挺好使.测试比sublime装插件要简单方便) MarkDown格式文本 名称 ======== ...