SSDT 由一个名为 Data-Tier Application Framework(也称为 DacFX)的库提供支持。 DacFX 是一个公共 API,可用于提取和发布 dacpac 文件。您可以在 Visual Studio 或 SQL Server 下的 Program Files 中找到 DacFX 的副本,该目录如下所示:
- C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\Extensions\Microsoft\SQLDB\DAC\130
- C:\Program Files (x86)\Microsoft SQL Server\130\DAC\bin
您可以在此处下载最新版本的 DacFX:
https://www.microsoft.com/en-us/download/details.aspx?id=51672
请注意,当您安装 DacFX 时,还需要安装其依赖项 SqlSysClrTypes 和 SqlDom,可在上述下载页面的系统要求部分找到。
要使用 DacFX 提取和发布 dacpac 文件,您可以使用SqlPackage.exe,如下所示:
C:\Program Files (x86)\Microsoft SQL Server\130\DAC\bin\SqlPackage.exe /a:extract /scs:"Data Source=YOURSERVER;Initial Catalog=YOURDB;Integrated Security=true" /tf:C:\temp\yourdb.dacpac
C:\Program Files (x86)\Microsoft SQL Server\130\DAC\bin\SqlPackage.exe /a:publish /tcs:"Data Source=YOURSERVER;Initial Catalog=YOUROTHERDB;Integrated Security=true" /sf:C:\temp\yourdb.dacpac
或者,您可以使用 Microsoft.SqlServer.Dac API 以编程方式使用 DacFX,如下所示:
using Microsoft.SqlServer.Dac;
class Program
{
static void Main(string[] args)
{
DacServices ds = new DacServices("Data Source=YOURSERVER;Initial Catalog=YOURDB;Integrated Security=true");
ds.Extract(@"C:\temp\yourdb.dacpac", "YOURDB", "AppName", new System.Version());
using (DacPackage dp = DacPackage.Load(@"C:\temp\yourdb.dacpac"))
{
ds.Deploy(dp, "YOUROTHERDB");
}
}
}