【问题标题】:WHERE Statement in MERGEMERGE 中的 WHERE 语句
【发布时间】:2019-02-15 08:13:13
【问题描述】:

如果 MERGE 语句在目标表和源表上都有条件,有人能解释一下 WHERE 将如何工作吗?例如:

merge into target_table t
using source source_table s
on s.flield = t.field
when matched then update (...)
when not matched then insert (...)
where t.field != <value> and s.field != <value>

我不知道如何解决t.field,因为源字符串与when not matched 子句中没有一个目标表字符串匹配。

我做了一些测试,所以在我看来,行将永远不会被插入。

我想知道:是否会插入任何行?

【问题讨论】:

  • 您的ON 子句在哪里? WHEN 中的那个条件和其他条件通常是应用任何约束的地方。
  • @Damien_The_Unbeliever thx 添加了 ON 子句。

标签: sql oracle merge


【解决方案1】:

来自the official Oracle documentation for MERGE statement

如果您希望数据库仅在指定条件为真时执行更新操作,请指定where_clause。条件可以引用数据源或目标表。如果条件不成立,则数据库在将行合并到表时跳过更新操作。

要明确回答您的问题(“我想知道:是否会插入任何行?”),答案是:否。

为什么?因为你有错误的语法。

您在 merge_insert_clause 中使用目标表列 (t.field),这是不允许的,它应该引发 ORA-38102: Invalid column in the INSERT WHERE Clause 错误:see this fiddle example!

来自文档:

merge_insert_clause 指定在 ON 子句的条件为假时插入到目标表列中的值。

如果您更准确地描述您想要插入的时间和想要更新的时间,我也会编辑我的答案并进一步说明如何操作。

希望我能帮上忙!

【讨论】:

  • 文档没有描述我的情况。如果您使用上述合并,则不会出错。我试图理解:是否会插入任何行?
  • @meowmeow 现在检查我的答案。我希望它现在更容易理解了
  • 在条件下尝试!=
  • @meowmeow 因为您之前已经在同一 field 列上加入了表,所以您只能在 merge_insert_clause 中使用源表列 (s.field)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-06-28
  • 2018-12-25
  • 1970-01-01
  • 2023-03-05
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多