1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

以下的文章主要是对Oracle merge into用法以及相关例子的介绍,首先我们以Oracle 9I中加入MERGE入手,以下就是文章的具体内容的分析,希望你浏览完之后会给你带来一些帮助在此方面。

语法:

MERGE[hint]INTO[schema.]table[t_alias] 
USING[schema.]{table|view|subquery}[t_alias] 
ON(condition) 
WHENMATCHEDTHENmerge_update_clause 
WHENNOTMATCHEDTHENmerge_insert_clause; 

创建测试数据表:

createtabletj_test(idnumber,namevarchar2(20),agenumber);

向表中插入数据:

insertintotj_testvalues(1,'jan',23); 
insertintotj_testvalues(2,'kk',22); 
insertintotj_testvalues(3,'joe',27); 
select*fromtj_test; 

查询结果如下:

1 jan 23

2 kk 22

3 joe 27

创建另一新表

createtabletj_test1asselect*fromtj_testwhere1=0

插入一条数据

insertintotj_test1values(1,'jlk',23); 
select*fromtj_test1 

查询结果如下:

1 jkl 23 –注意,这里的的NAME字段中的值是jkl

Oracle merge into用法使用MERGE,实现有则更新,无则插入,sql语句如下:

mergeintotj_test1tt1 
usingtj_testtt 
on(tttt1.id=tt.id) 
whenmatchedthen 
updateset 
tttt1.name=tt.name, 
tttt1.age=tt.age 
whennotmatchedthen 
insertvalues( 
tt.id, 
tt.name, 
tt.age) 

查询tj_test1表(对比原来表中的数据,更新了ID=1 ROW中字段NAME,同时多出两条新数据)

select*fromtj_test1

改变行数据如下:

1 jan 23 –这里的原有jkl值被更新

3 joe 27 –原来表中没有的插入

2 kk 22 –原来表中没有的插入

如果存在就更新,不存在就插入

9i已经支持了,是Merge,但是只支持select子查询,

如果是单条数据记录,可以写作select …… from dual的子查询。

语法为:

MERGEINTOtable 
USINGdata_source 
ON(condition) 
WHENMATCHEDTHENupdate_clause 
WHENNOTMATCHEDTHENinsert_clause; 

如:

MERGEINTOcoursec 
USING(SELECTcourse_name,period, 
course_hours 
FROMcourse_updates)cu 
ON(c.course_name=cu.course_name 
ANDc.period=cu.period) 
WHENMATCHEDTHEN 
UPDATE 
SETc.course_hours=cu.course_hours 
WHENNOTMATCHEDTHEN 
INSERT(c.course_name,c.period, 
c.course_hours) 
VALUES(cu.course_name,cu.period, 
cu.course_hours); 

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11293.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。