- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们更改了我们的部署脚本以使用 liquibase 但现在我开始遇到一些问题,我想发表其他意见或者可能知道一个合适的解决方案。
我们使用的是 Oracle,我们有很多遗留代码:包、函数、过程、触发器..(如您所见,数据库中有很多逻辑)。
我们使用以下结构:
.
..
packages
functions
triggers
baseline
S1301
S1302
S1312
xxx-changelog.xml
xx-changelog.xml 如下所示:
<include file="baseline/xxx-baseline-changelog.xml" relativeToChangelogFile="true" />
<!- Sprint change logs -->
<include file="S1304/xxx-s1304-changelog.xml" relativeToChangelogFile="true" />
<include file="S1308/xxx-s1308-changelog.xml" relativeToChangelogFile="true"/>
<include file="S1309/xxx-s1309-changelog.xml" relativeToChangelogFile="true"/>
<include file="S1310/xxx-s1310-changelog.xml" relativeToChangelogFile="true"/>
<include file="S1311/xxx-s1311-changelog.xml" relativeToChangelogFile="true"/>
因为我们不想每次都在新文件夹中复制文件,我们指向同一个文件,并且因为我们正在更改内容,所以我们必须设置 runOnChange 属性,因为如果我们不这样做,它将失败。
问题是我们在敏捷中工作,每 3 周我们交付新代码,有时我们必须在一个冲刺中更改一个包,而我们必须在下一个冲刺中更改相同的包。
我的情况是:
1) 如果我们为每个 sprint 添加一个新的 changeSet,指向 packages 文件夹中的文件,例如使用 runOnchange,这将执行所有指向这些文件的 changeSet,因为内容不同,并且是 runOnchange (这不是我想要的)。但这是了解冲刺中的变化并对此进行跟踪的唯一方法。
xxx-s1311-changelog.xml
<changeSet id="XXX_SEND_TO_PP_PCK_S1311" author="e-ballo" runOnChange="true">
<sqlFile path="../packages/XXX_SEND_TO_PP_PCK.pkb" splitStatements="false" relativeToChangelogFile="true"/>
</changeSet>
xxx-s1312-changelog.xml
<changeSet id="XXX_SEND_TO_PP_PCK_S1312" author="e-ballo" runOnChange="true">
<sqlFile path="../packages/XXX_SEND_TO_PP_PCK.pkb" splitStatements="false" relativeToChangelogFile="true"/>
</changeSet>
2) 如果我们只为包创建一个文件 (packages-changelog.xml) 并且我们为包添加 changeSet 属性为 runOnChange,每次文件更改时都会运行,但您无法了解我们何时更改它。
也许最好的解决方案是将文件(包)复制到 sprint 的文件夹中,但我想在 SVN 中保留文件的历史记录,同时也清楚地了解 sprint 中的新变化更改日志。
我的问题:
如果有什么方法可以禁用 liquibase 中的 hashmap,你们知道吗?然后我将能够在每个 sprint 中添加它并有一个跟踪..如果 id 已经在数据库中不应该再次执行,对吗?
提前致谢
最佳答案
我知道这是旧的,为将来遇到它的任何人回答。
不,校验和在 Liquibase 的工作方式中根深蒂固,runOnChange 是执行此操作的正确方法。问题是你应该更细化你的变更日志。请记住:变更日志可以包含其他变更日志。
if we add a new changeSet for each sprint, pointing to the file in packages folder, for example with runOnchange, this will execute all the changeSet that are pointing to these file because the content is diferent, and is runOnchange (is not what i want). But is the only way to know the changes in the sprint, and have track of this.
你的项目结构很好,你只需要更进一步。制作实际的变更日志以安装包/函数/触发器/等这些目录的一部分,因为一旦写入它们可能永远不需要更改:
.
├── functions
│ ├── my_function_changelog.xml
│ └── sql
│ └── my_function.sql
├── packages
│ ├── my_package_changelog.xml
│ └── sql
│ └── my_package.sql
└── triggers
├── my_trigger_changelog.xml
└── sql
└── my_trigger.sql
然后,当您需要在您的发布中包含一个时,您可以包含该静态变更日志,而不是每次都定义一个新的变更集(正如您所发现的,这会使 Liquibase 感到困惑):
<include file="../packages/my_package_changelog.xml" relativeToChangelogFile="true" />
现在您可以跟踪每个冲刺中所做的事情,而不会意外地重新安装您不想安装的包。
关于oracle - 良好做法 - 使用 LiquiBase 包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18713971/
Oracle 即时客户端和 Oracle 客户端有什么区别?你能给我解释一下吗?谢谢 最佳答案 Oracle 客户端带有安装程序和许多可执行文件,例如 sqlplus,tnsping,它是完整而庞大的
我正在寻找一个Delphi组件来直接连接到ORACLE数据库服务器,而无需安装oracle客户端。 我知道Oracle Data Access (ODAC)来自DevArt 。还有其他组件具有此功能吗
如何编写 Oracle 存储过程,以表 (X) 作为输入参数,并在过程内部使用表 X 来与另一个表 Y 联接? 表 X 将包含数千条记录。 不希望将表名作为 varchar 传递,然后使用动态 SQL
如何编写 Oracle 存储过程,以表 (X) 作为输入参数,并在过程内部使用表 X 来与另一个表 Y 联接? 表 X 将包含数千条记录。 不希望将表名作为 varchar 传递,然后使用动态 SQL
我要过滤COMMENTS属性为空的记录 我试过了 SELECT TABLE_NAME, COMMENTS FROM (SELECT TABLE_NAME, COMMENTS FROM (sel
我要下载 Oracle Instant Client for Linux x86-64 (64-bit)现在有一段时间了。 现在我注意到该网站在过去几个月中一直遇到技术问题。 要从 Oracle 下载
有什么方法可以将我的 Delphi 应用程序 (FireDac) 直接连接到 Oracle 数据库? 目前可以连接,但需要安装Oracle Client 在 embarcadero 站点 ( http
我有一张表,其中日期列的数据格式如下:“7/25/2014 12:14:27 AM”。我需要通过放入 where 子句来获取此日期。有人可以建议我该怎么做吗? 最佳答案 日期(存储在表中)是 repr
如果两个事务试图同时修改同一行会发生什么?通常,一旦行被修改,另一个事务等待直到第一个事务执行提交或回滚。但是,如果他们恰好在同一时刻发送更新请求怎么办? 最佳答案 答案是否定的。两个事务不能同时修改
我想知道为什么我不能在 Oracle 模式中有两个同名的索引?它抛出一个错误,指出该名称已被使用。我的印象是,由于索引在一个特定的表上,这应该不会导致任何错误,除非我们对同一个表上的两个不同列使用相同
我需要构建一个查询来按成员和到期日期检索信息组,但我需要为每个成员提供一个序列号.. 例如: 如果成员“A”有 3 条记录要过期,“B”只有 1 条,“C”有 2 条,我需要这样的结果: Number
独立程序 create procedure proc1 ( begin end; ) 存储过程 create package pkg1 ( procedure proc2 begin end; ) 最
在 Oracle 9i 中声明 FK 时遇到问题。我在这里查看了许多关于 SO 和一些在线文档(例如 http://www.techonthenet.com/oracle/foreign_keys/f
我和我的同事维护的应用程序在后端有一个 Oracle 数据库。我们正在考虑偶尔以“受限”模式运行应用程序,其中一个数据库表空间设置为只读。我们可以轻松地将必要的表和索引移动到单独的表空间,这些表空间将
我想实现一个自定义的回归聚合函数,类似于现有的 REGR_SLOPE . 我要定义的函数需要获取两列作为参数,例如 select T.EMPLOYEE_ID, CUSTOM_REGR_SL
我已经尝试解决这个问题一段时间了,我认为是时候寻求帮助了。我正在构建一个架构配置脚本,我想添加一些脚本输出和错误处理。这个想法是脚本输出窗口只会向我显示关键消息而没有所有噪音。 Create Temp
在旧的 Oracle 服务器(我被告知是 8i)上使用 JDBC 时,我遇到了一个非常令人困惑和奇怪的问题。我在那里准备了一个表,其中包含大约 10 列、数字、varchars、一个 raw(255)
我有一张 table Customer_Chronics在 Oracle 11g 中。 该表具有三个关键列,如下所示: 分支代码 客户 ID 期 我已按 branch_code 列表按表分区,现在我进
是否有存储用户自定义异常的oracle表? 最佳答案 没有。 与其他变量一样,用户定义的异常在 PL/SQL block 中定义,并且具有 PL/SQL 变量将具有的任何范围。所以,例如 DECLAR
在 oracle 中使用序列并使用 Before insert trigger 自动递增列或使用标识列是否更好,因为它在 Oracle 12 c 中可用? 最佳答案 无论哪种方式,您都将使用序列。 1
我是一名优秀的程序员,十分优秀!