Oracle Streams 如何在分发过程中阻止代码的执行?

Oracle Streams 如何在分发过程中阻止代码的执行?

我思考了 Oracle Streams 并遇到了一个问题。

我编程的数据库使用了 Oracle Streams,但我不是 DBA。因此,我不熟悉数据库的配置。我只是对 Streams 的实际功能有一个“简单”的了解。

在我看来,它可以保持多个分布式数据库之间的数据一致性。现在我要问的是:

假设我们有两个通过 Oracle Streams 匹配的数据库 A 和 B。它们都是基于相同的架构、表和触发器构建的。如果在数据库 A 中的表 T1 上插入了数据,则数据将通过 Streams 分发到数据库 B 中的表 T1。

但是,如果表 T1 有一个插入触发器 TR1,情况会怎样?在 T1 中插入时,它肯定会在数据库 A 上执行,但是如果流将数据从 A 分发到 B,数据库 B 上会发生什么?触发器会执行吗?我想不会,因为这可能带来很多麻烦。

Streams 是否会在通过其自身分发数据期间阻止任何代码的执行?

答案1

会发生什么取决于触发器是否设置为一次点火

如果触发器设置为触发一次,那么更改将应用​​于数据库 A,并且 Streams 会忠实地将它们复制到数据库 B。这听起来就是您想要的。

否则,当 Streams 复制导致触发器在数据库 A 上触发的更改后,触发器将在数据库 B 上再次触发。

哪种方法适合于特定情况取决于触发器的作用。

Oracle 的文档以获得更完整的解释和另一个例子。

相关内容