12

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

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

如果我想让后部署脚本只运行一次脚本,有没有一种方法可以做到这一点,而不需要数据库中的版本或历史记录表来记录这些脚本已经运行的时间?

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

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

4

1 回答 1

11

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

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

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

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

于 2013-07-24T22:14:10.293 回答