Welcome 微信登录

首页 / 数据库 / MySQL / Oracle merge into用法及例子

Oracle 9I中加入了MERGE 语法: MERGE [hint] INTO [schema .] table [t_alias] USING [schema .] { table | view | subquery } [t_alias] ON ( condition ) WHEN MATCHED THEN merge_update_clause WHEN NOT MATCHED THEN merge_insert_clause; 创建测试数据表: create table tj_test(id number,name varchar2(20),age number); 向表中插入数据: insert into tj_test values (1,"jan",23); insert into tj_test values (2,"kk",22); insert into tj_test values (3,"joe",27); select * from tj_test; 查询结果如下: 1 jan 23 2 kk 22 3 joe 27 创建另一新表 create table tj_test1 as select * from tj_test where 1=0 插入一条数据 insert into tj_test1 values (1,"jlk",23); select * from tj_test1 查询结果如下: 1 jkl 23 --注意,这里的的NAME字段中的值是jkl 使用MERGE,实现有则更新,无则插入,sql语句如下: merge into tj_test1 tt1 using tj_test tt on (tt1.id=tt.id) when matched then update set tt1.name=tt.name, tt1.age=tt.age when not matched then insert values( tt.id, tt.name, tt.age) 查询tj_test1表(对比原来表中的数据,更新了ID=1 ROW中字段NAME,同时多出两条新数据) select * from tj_test1 改变行数据如下: 1 jan 23 --这里的原有jkl值被更新 3 joe 27 --原来表中没有的插入 2 kk 22 --原来表中没有的插入 如果存在就更新,不存在就插入 9i已经支持了,是Merge,但是只支持select子查询, 如果是单条数据记录,可以写作select …… from dual的子查询。 语法为: MERGE INTO table USING data_source ON (condition) WHEN MATCHED THEN update_clause WHEN NOT MATCHED THEN insert_clause; 如: MERGE INTO course c USING (SELECT course_name, period, course_hours FROM course_updates) cu ON (c.course_name = cu.course_name AND c.period = cu.period) WHEN MATCHED THEN UPDATE SET c.course_hours = cu.course_hours WHEN NOT MATCHED THEN INSERT (c.course_name, c.period, c.course_hours) VALUES (cu.course_name, cu.period, cu.course_hours);入侵Oracle服务器进一步获取权限Oracle中start with...connect by prior子句用法相关资讯      oracle 
  • [INS-32052] Oracle基目录和Oracle  (07/22/2014 07:41:41)
  • Oracle 4个大对象(lobs)数据类型  (02/03/2013 12:33:05)
  • Oracle按时间段分组统计  (07/26/2012 10:36:48)
  • [Oracle] dbms_metadata.get_ddl的  (07/12/2013 07:37:30)
  • Liferay Portal 配置使用Oracle和  (07/31/2012 20:07:18)
  • Concurrent Request:Inactive   (07/20/2012 07:44:05)
本文评论 查看全部评论 (0)
表情: 姓名: 字数