Merge Sql
我们经常遇到的一个需求是,先判断数据是否存在,如果存在则更新,否则就插入,以前比较土是用java自己做了。这个在多线程或者多机的情况下就会有些问题,有时候还得让db报个唯一性约束才行。最近和一个同事(以前是oracle的)做项目,发现他写了个牛逼的sql(或者说自己见识太短浅了),特此膜拜下
类似这样的
MERGE INTO test1 aUSING all_objects b ON (a.object_id = b.object_id)WHEN MATCHED THEN UPDATE SET a.status = b.status WHEREb.status != 'VALID'WHEN NOT MATCHED THEN INSERT (object_id, status) VALUES (b.object_id, b.status) WHEREb.status != 'VALID'; 查了些资料发现这种merge sql早就被支持了,只是自己还不知道而已。
<--------------------------------------不华丽的分界线--------------------------------------------------------------------->
例如wiki上的 http://en.wikipedia.org/wiki/Merge_%28SQL%29
Merge (SQL)
From Wikipedia, the free encyclopedia
页:
[1]