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

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

君子好学,自强不息!

Oracle merge into的实操示例

2022-11-26 | 数据库 | 1818ip | 602°c
A+ A-

如果你是Oraclemergeinto即Oracle9I中加入了MERGE用法及例子方面的新手,对Oraclemergeinto即Oracle9I中加入了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

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

Oraclemergeintotj_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; 

如:

Oraclemergeintocoursec 
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/11782.html

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

发表评论

必填

选填

选填

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