我正在使用 JDBI3(并且想使用@SQLUpdate)和一个 Oracle 数据库。
如果它不存在,我想将一个具有 4 列的项目插入到表中,如果它确实存在,我想更新该项目的 4 个值中的 3 个。如果不是甲骨文,我会使用一些ON DUPLICATE_KEY
逻辑,但甲骨文中不存在。我读了一些关于使用 Merge 的东西,但是对于我想要做的事情来说,查询似乎真的很不稳定。关于寻找什么的任何提示?
附加问题:如果我应该使用 Merge(我假设使用某种形式的子查询),查询如何影响性能?我认为这个数据库写得很重。
MERGE INTO device db USING (SELECT 'abc' AS col1, 'bcd' as col2, 'cde' as col3, 'def' as col4 FROM DUAL) input
on (db.col1 = input.col1 AND db.col2= input.col2)
WHEN MATCHED THEN UPDATE
SET db.col4 = input.col4
WHEN NOT MATCHED THEN INSERT
(db.col1, db.col2, db.col3, db.col4)
VALUES (input.col1, input.col2, input.col3, input.col4)