1

我正在使用带有 GDR 版本 9.1.40413.00 的 Visual Studio Team System 2008,并试图解决将单个数据库项目部署到多个数据库的问题。例如,如果我有一个 Performance.DB 项目,我想部署名为 Performance、Performance2、Performance3 等的数据库。

但是,如果您转到数据库项目的属性,您似乎只能有 1 个部署目标。有办法解决这个问题吗?我还希望每个 Performance db 都有自己的 sqlcmdvars 文件,这样它就有自己独特的 mdf 和 ldf 文件。

如果从项目中的属性中无法做到这一点,那么是否有一种方法可以创建一个批处理脚本,该脚本将为我要部署的每个数据库多次执行例如以下命令 - 当我部署项目时?

"D:\Program Files\Microsoft Visual Studio 9.0\VSTSDB\Deploy\vsdbcmd.exe" /ManifestFile:"D:\Performance\Test\Binaries\Release\Performance.DB.deploymanifest" /a:Deploy /cs:"Data Source=.\SQLEXPRESS;Integrated Security=True;Pooling=False" /p:GenerateDropsIfNotInProject=True /p:BlockIncrementalDeploymentIfDataLoss=False /p:TargetDatabase=Performance /p:SqlCommandVariablesFile="D:\Performance\Test\Binaries\Release\Performance.sqlcmdvars" /p:IgnorePermissions=True /p:GenerateDeployStateChecks=False /dd:+
4

3 回答 3

0

我最近遇到了类似的情况,想要一个具有一组“基本”对象的数据库项目,这些对象可以部署到多个“子”数据库中。为了解决这个问题,我们的团队使用复合项目 (http://msdn.microsoft.com/en-us/library/dd193415.aspx) 来定义我们的基础和子数据库,然后设置多个构建配置。每个构建配置都允许您指定不同的目标、sqlcmdvars 等,并且基本上可以定制构建以一次仅部署到一个数据库。

这意味着要部署所有性能数据库,您需要更改每个数据库的构建配置,或者如果在 TFS 中部署/单元测试,请为您拥有的每个构建配置创建具有不同 .config 文件的多个测试设置文件。

于 2012-04-17T18:58:44.167 回答
0

通过 *.dbproj 文件中的一些 MSBUILD 黑客攻击,我想出了一个在 AfterDeploy 事件中仅调用自身第二次/n 次的项目,因此您可以使用单个“部署”命令部署到多个数据库:

 <PropertyGroup>
    <TargetDatabase>Performance</TargetDatabase>
    <TargetDatabase Condition="$(SecondDatabase)!=''">$(SecondDatabase)</TargetDatabase>
  </PropertyGroup>


 <Target Name="AfterDeploy">
    <MSBuild Condition="$(SecondDatabase)==''" Targets="Deploy" Properties="SecondDatabase=Performance2" Projects="$(ProjectPath)" />
    <MSBuild Condition="$(SecondDatabase)==''" Targets="Deploy" Properties="SecondDatabase=Performance3" Projects="$(ProjectPath)" />
  </Target>
于 2012-04-19T12:48:37.330 回答
0

您可以尝试查看部分数据库项目。

这是一个示例http://blogs.msdn.com/gertd/archive/2008/10/05/partial-projects.aspx

它们对于将代码从一个数据库项目共享到另一个数据库项目很有用,尽管在整个项目规模上它可能不是那么好。

使用它,您的核心性能数据库项目将是“基础”项目,所有其他项目都将从中派生。

于 2009-10-11T01:04:56.827 回答