在Oracle中,给出一个简单的数据表:
create table data ( id VARCHAR2(255), key VARCHAR2(255), value VARCHAR2(511));
假设我想"插入或更新"一个值.我有类似的东西:
merge into data using dual on (id='someid' and key='testKey') when matched then update set value = 'someValue' when not matched then insert (id, key, value) values ('someid', 'testKey', 'someValue');
有比这更好的方法吗?这个命令似乎有以下缺点:
每个文字需要输入两次(或通过参数设置添加两次)
"使用双重"语法看起来很糟糕
如果这是最好的方法,有没有办法在JDBC中设置两次每个参数?
我不认为使用双重作为黑客.为了摆脱绑定/打字两次,我会做类似的事情:
merge into data using ( select 'someid' id, 'testKey' key, 'someValue' value from dual ) val on ( data.id=val.id and data.key=val.key ) when matched then update set data.value = val.value when not matched then insert (id, key, value) values (val.id, val.key, val.value);