dikar 发表于 2013-1-25 21:48:47

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]
查看完整版本: Merge Sql