gpt4 book ai didi

sql - ssdt 部署后脚本运行一次

转载 作者:行者123 更新时间:2023-12-04 03:52:18 24 4
gpt4 key购买 nike

我是 SQL Server 数据库工具的新手,可能对部署后脚本正在做什么做出了不正确的假设。如果我错了,请纠正我。

据我所知,部署后脚本预计将在每次部署后运行,而不仅仅是一次部署。

如果我想让部署后脚本只运行一次脚本,有没有办法做到这一点,而无需数据库中的版本或历史记录表来记录这些脚本何时运行?

即我是否可以将脚本的任何后续修改添加为项目中的新文件,并添加版本号,并将其添加到部署后脚本,但是否可以忽略先前的脚本(可能无需先删除它)?不管它在部署期间是否仍然运行脚本?

是否有这种事情的配置还是这种意外行为?

最佳答案

部署前和部署后脚本旨在在您每次发布项目时运行。您的最佳做法是使它们可重复。添加检查,以便如果数据已经存在,您就不会再次运行或类似的东西。您也可以构建某种基本的日志记录表来存储它 - 如果在表中找不到行,请运行脚本并将行放入表中。

如果存在多个脚本,您不能告诉项目只运行最新版本的脚本,因为它们都内置在一个大型 PreDeploy.sql 或 PostDeploy.sql 文件中。您需要在每个部分/脚本中添加一些内容来告诉它在哪里查看以了解是否要运行。这可能是现有的数据检查、表检查、版本检查或其他东西,但它需要知道在某处使用什么来知道是否运行。

除了注释掉脚本或通过 SQLCMD 变量或其他检查以某种方式处理它们之外,没有办法关闭它。这些仍然需要您以每个脚本应该运行或不应该运行的方式进行编码。如果您提供一两个示例,说明您要在部署前/部署后脚本中完成的任务,我们可能会提供一些更好的指导。

出于我们的目的,我们使脚本可重复使用,并在运行时将其删除。它们仍处于源代码控制中,或者您可以在删除它们之前使用快照来存储该项目版本。

关于sql - ssdt 部署后脚本运行一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17822346/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com