4

目前使用 SqlPackage.exe 命令行工具生成脚本,通过将 DacPac 文件与目标数据库进行比较。如果数据库不存在,这将创建数据库。

我们现在想将其切换为使用 Microsoft.Data.Tools.Msbuild Nuget 包(使用 C# 进行部署),但是当数据库容器不存在时,使用 SchemaComparison 进行比较会失败。似乎没有太多与该软件包相关的文档。

这个包中是否有任何工具可以让我在比较之前创建一个空的数据库容器?

我目前正在使用以下代码(在与现有数据库进行比较时有效):

 SchemaCompareDacpacEndpoint sourceDacpac = new SchemaCompareDacpacEndpoint(@"C:\DeployDB.dacpac");

        SqlConnectionStringBuilder csb = new SqlConnectionStringBuilder();
        csb.DataSource = @".";
        csb.InitialCatalog = "DeployTestDB";
        csb.IntegratedSecurity = true;
        SchemaCompareDatabaseEndpoint targetDatabase = new SchemaCompareDatabaseEndpoint(csb.ToString());


        SchemaComparison comparison = new SchemaComparison(sourceDacpac, targetDatabase);
        comparison.Options.DropObjectsNotInSource = true;
        comparison.Options.BlockOnPossibleDataLoss = false;
        comparison.Options.TreatVerificationErrorsAsWarnings = true;
        comparison.Options.ScriptDatabaseOptions = true;
        comparison.Options.GenerateSmartDefaults = true;

        SchemaComparisonResult comparisonResult = comparison.Compare();

此时,ComparisonResult 出现错误消息:{Error SQL0: Cannot open database "DeployTestDB" requested by the login. 登录失败。用户“myUsername”登录失败。}

4

1 回答 1

4

看看 Microsoft.SqlServer.Dac.dll 中的 DacServices 类。

代码看起来像这样:

using Microsoft.SqlServer.Dac;

class Program
{
    static void Main(string[] args)
    {
        DacServices ds = new DacServices(@"Data Source=SERVERNAME;Initial Catalog=DATABASENAME;Integrated Security=true");
        using (DacPackage dp = DacPackage.Load(@"C:\temp\mydb.dacpac"))
        {
            ds.Deploy(dp, @"DATABASENAME", upgradeExisting: false, options: null, cancellationToken: null);
        }
    }
}
于 2017-07-25T18:47:13.753 回答