- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有一些自动化的 dacpac 部署代码,可以使用 Microsoft.SqlServer.Dac
在 C# 中正确处理 CreateNewDatabase 和直接更新数据库场景
现在,在 CreateNewDatabase 案例中,我们希望能够在禁用部署前脚本和部署后脚本的情况下运行 DacServices.Deploy()
。 IE。在这种情况下不应执行它们。
我试图在 DacDeployOptions
和 DacServices
对象中找到合适的位置,但找不到任何可以做到这一点的地方。理想情况下
问题 1:我想要像 DacDeployOptions.IgnorePreDeploymentScript = true
这样的东西,有什么方法可以在运行时实现吗?
作为替代方案,我记得前段时间看到示例代码显示如何遍历 dacpac 并在运行时创建新的 dacpac。我认为这种方法可以让我简单地创建一个新的 dacpac,我可以将其传递给 Deploy 并且排除部署前和部署后脚本。我不喜欢这个解决方案,但它可以让我实现我所需要的。
问题 2:谁能给我指出一些例子吗?
我的代码:
var dacService = new DacServices(ConstDefaultConnectionString);
using (var dacPackage = DacPackage.Load(dacPacFilePath))
{
var deployOptions = new DacDeployOptions
{
CreateNewDatabase = true,
IncludeTransactionalScripts = false
};
dacService.Deploy(dacPackage, TestDatabaseName, true, deployOptions);
}
问题是关于:Create LocalDB for testing from Visual Studio SQL project
最佳答案
为此您可以采取多种方法,这有点脑残(嘿,昨晚时钟倒退了,我什至不确定当前时间是否正确):
1) 使用相同的数据库引用创建一个引用您的主项目的空项目 - 当您在没有脚本的情况下部署时使用 IncludeCompositeObjects 部署空项目 - 部署前/后脚本仅从您部署的 dacpac 运行,而不是从任何引用的dacpacs 但显然代码和方案已部署。这是这样描述的:
2) 使用 SQLCMD 变量包装数据设置并将值传递给部署。
3) 让你的脚本检查它们是否应该设置数据,比如只在表行数为零时才插入
4) 对于引用数据使用合并脚本——我不清楚这是为了引用数据还是设置测试数据
5) 使用 .net 打包 api 从 dacpac 中删除部署前/后脚本,这向您展示了如何编写脚本,以便您应该能够执行 GetPart 而不是 WritePart:
https://github.com/GoEddie/Dir2Dac/blob/master/src/Dir2Dac/DacCreator.cs
总的来说,我猜想可能有一个更简单的解决方案——如果这是为了测试,那么也许可以将数据设置作为测试设置的一部分?如果您正在进行单元测试,tSQLt 可以通过使用 FakeTable 帮助您避免这一切。
希望对您有所帮助:)
埃德
关于c# - 如何在 DacServices.Deploy() 中禁用部署前和部署后脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43022266/
我是 DevOps 的新手。我为刚刚在 Digital Oceans 上创建的 Kubernetes 集群编写了一个 deployment.yaml 文件。创建部署不断出现我现在无法解码的错误。这只是
我需要能够在 Red5 运行时进行部署。我知道的唯一解决方案是使用 WAR 文件并将其放在文件夹中:webapp。 还有其他办法吗? 我使用的是 Red 5 v0.8。我使用 Eclipse 3.4
我收到以下错误: Recycling (Waiting for role to start... Sites are being deployed. [2012-12-17T05:30:10Z]) R
使用 TeamCity 6.5,我试图弄清楚如果可能的话,如何为特定的构建运行设置手动部署。 我希望能够做的是运行已经构建和测试的 TeamCity(仅需要部署工件 - 这不是 Web 应用程序或站点
我看到一个范围为环境的编辑变量权限。但是,似乎谁负责设置项目,谁就会负责创建变量,而其他一些安全实体将只负责修改值,特别是安全值。这可能吗? 编辑:再补充一点,我想我是在根据项目变量集请求权限。只有拥
在我通过命令部署到我的服务器后: bin/dep deploy 在“releases ”文件夹中,我有名为喜欢的文件夹 1 , 2 , 3 , ... 我怎样才能把它改成时间戳,所以在部署命令之后我会
问题: 我有一个手动干预步骤,其中包含执行部署的人员要遵循的文本步骤。 我想传递目标服务器的名称,这样这个人就不需要查找目标服务器名称。 例如,如下所示,我需要将它们解压缩到目标服务器上的某个位置。
这是一个系统 Octopus 部署变量: #{Octopus.Action[Deploy To Server].Output.Package.InstallationDirectoryPath} 文本
我正在尝试在 Octopus Deploy 中设置部署。与许多其他开发人员一样,我通过迭代来做到这一点:调整步骤/脚本/包 -> 单击“部署” -> 检查结果 -> 如果不满意,则重新开始。在 Oct
在使用 Network Deployment 安装 WebSphere Application Server 时,节点是: 物理机 操作系统实例 一组独立于物理机或操作系统实例的逻辑 WAS 实例 最
我知道目前有一个 feature request对于这样的事情,但我希望使用当前版本(1.6)有某种解决方法 我们从 TFS 中的开发分支为我们的开发和测试环境构建,并从 TFS 中的发布分支为我们的
我正在尝试运行由 MSBuild 生成的 ProjectName.deply.cmd 当参数 /p:DeployOnBuild=True通过。参数“ComputerName”之一将作为 https:/
有时首选和/或需要在单个服务器上托管数十个应用程序。不是说这是“对”或“错”,我只是说它发生了。 此配置的缺点是出现错误消息Waiting for the script in task [TASK I
部署准备使用的 erlang 应用程序时我 不要希望用户 在上找到正确的 erl 版本 互联网。 安装 erl vm 解压缩并确定梁文件的位置(与应用程序一起) 阅读自述文件 修改任何看起来像配置文件
使用Next.js创建的app部署到netlify时,出现如下错误,部署失败。 ────────────────────────────────────────────────────────────
我有一个包含两个模块的项目:客户端和服务器。在父 pom.xml 中,我添加了部署阶段的信息,以便部署到本地目录: 4.0.0 org.my myTest 0.1 pom m
我们正在运行 OD 1.6。 我想使用 OD 变量来更改不在应用设置部分中的值,例如 session 状态提供程序。 我知道我可以为此使用转换,但作为一家公司,我们更喜欢使用 OD 变量而不是转换,因
Plesk Obsidian 提供 GIT 部署,我们正在尝试将其配置为类似于我们之前在 CPANEL 上的配置(我们最近从与 CPANEL 的共享帐户升级到与 Plesk 的 VPS - Plesk
我对这个主题进行了大量研究,但找不到任何端到端解决方案来使用 TFS 2010 实现“一次构建并部署多次”。 基本上我在想的是有一个构建定义,它将构建一个解决方案,其中包含多个要部署的项目(Web 应
我已经阅读了关于如何使用 pm2 的几个问题和想法。在 Windows 机器下,不管你信不信,我以前的机器运行得很好......然后我不得不重新格式化它并完全忘记了我以前做过的事情:( 我已经安装了
我是一名优秀的程序员,十分优秀!