Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/visual-studio-2008/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server GDR-使用一个项目部署多个数据库目标_Sql Server_Visual Studio 2008_Gdr - Fatal编程技术网

Sql server GDR-使用一个项目部署多个数据库目标

Sql server GDR-使用一个项目部署多个数据库目标,sql-server,visual-studio-2008,gdr,Sql Server,Visual Studio 2008,Gdr,我正在将VisualStudioTeamSystem2008与GDR版本9.1.40413.00一起使用,并试图解决将单个DB项目部署到多个数据库的问题。例如,如果我有一个Performance.DB项目,我希望部署名为Performance、Performance2、Performance3等的数据库 但是,如果转到数据库项目的属性,则似乎只能有一个部署目标。有办法解决这个问题吗?我还希望每个性能数据库都有自己的sqlcmdvars文件,这样它就有自己独特的mdf和ldf文件 如果无法从项目内

我正在将VisualStudioTeamSystem2008与GDR版本9.1.40413.00一起使用,并试图解决将单个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:+

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

这里有一个例子

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


使用此选项,您的核心性能数据库项目将成为“基本”项目,其他所有项目都将从中派生。

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


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

在*.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>

演出
$(第二数据库)