我正在使用带有GDR版本9.1.40413.00的Visual Studio Team System 2008,并试图解决将单个DB项目部署到多个数据库的问题。例如,如果我有一个Performance.DB项目,我想部署名为Performance、Performance2、Performance3等的数据库。
但是,如果转到数据库项目的属性,似乎只能有一个部署目标。有什么办法可以解决这个问题吗?我还希望每个性能数据库都有自己的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:+发布于 2009-10-11 01:04:57
您可以尝试查看部分数据库项目。
下面是一个http://blogs.msdn.com/gertd/archive/2008/10/05/partial-projects.aspx示例。
它们对于将代码从一个数据库项目共享到另一个数据库项目很有用,尽管在整个项目规模上可能不是那么好。
使用它,您的核心性能数据库项目将是“基础”项目,所有其他项目都将由此派生。
发布于 2012-04-18 02:58:44
我最近遇到了类似的情况,想要一个具有一组“基础”对象的数据库项目,这些对象被部署到多个“子”数据库中。为了解决这个问题,我们的团队使用复合项目(http://msdn.microsoft.com/en-us/library/dd193415.aspx)来定义我们的基础数据库和子数据库,然后设置多个构建配置。每个构建配置允许您指定不同的目标、sqlcmdvars等,并基本上定制构建,以便一次仅部署到一个数据库。
这意味着要部署所有的性能数据库,您将需要更改每个数据库的构建配置,或者如果在TFS中部署/单元测试,则需要为每个构建配置创建多个具有不同.config文件的测试设置文件。
发布于 2012-04-19 20:48:37
通过对*.dbproj文件进行一些MSBUILD黑客攻击,我想出了一个在AfterDeploy事件中只调用自己第二次/n次的项目,这样你就可以使用一个' deploy‘命令来部署到多个数据库:
<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>https://stackoverflow.com/questions/1544966
复制相似问题