1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > oracle merge into的使用

oracle merge into的使用

时间:2024-04-12 01:07:59

相关推荐

oracle merge into的使用

数据库|mysql教程

oracle,merge,into,使用,在做,报表,时候,

数据库-mysql教程

ASP NET 在线考试系统源码,ubuntu待机后死机,爬虫准确性,php 复式记账,seo 是啥lzw

在做报表的时候,遇到这么一个问题,由于数据量大,数据上传时间问题,经常要处理更新几天前的数据,这时需要涉及UPDATE或者INSERT两个操作,这时推荐用MERGE INTO,但用这个时候需注意一个问题,我先来一个测试: SQL select * from ytrep.tab1; COL_A COL_B

手机如何制作网站源码,vscode调试能力,苹果ipad运行ubuntu,jks证书tomcat,sqlite arm编译,bootstrap grid插件,前端有哪些框架技术,爬虫飞鸟游鱼,php 执行php,SEO教研计划,手机版交友网站代码,jquery 获取指定网页的内容,.net 开发模板,js购物车结算页面,宾馆管理系统源码下载,人人商城小程序diy源码下载lzw

征途2脚本源码,vscode怎么java,ubuntu wen,tomcat异常500,sqlite断电数据丢失,dz插件图片本地化,ssm框架搭建后与前端,9E看看爬虫,php 日期 天数,武汉seo推广托管,企业网站资源共享,自动切换网页软件,带会员系统的网站模板lzw

在做报表的时候,遇到这么一个问题,由于数据量大,数据上传时间问题,经常要处理更新几天前的数据,这时需要涉及UPDATE或者INSERT两个操作,这时推荐用MERGE INTO,但用这个时候需注意一个问题,我先来一个测试:

SQL> select * from ytrep.tab1;

COL_ACOL_BCOL_C

———- ———- ———-

1A

2B

3C

4D

5E

6F

7G

8H

8 rows selected

SQL> select * from ytrep.tab2;

COL_ACOL_BCOL_CCOL_D

———- ———- ———- ———-

1AA1 1

1AA1 2

2BB1 1

3CC1 1

4DD1 1

5EE1 2

5EE2 1

6FF1 1

6FF1 2

9GG1 1

10 HH1 1

11 rows selected

有以上两表,其中需要根据ytrep.tab2表的col_a及col_b值来更新ytrep.tab1的col_c值,这时,我们来执行以下SQL:

Merge into ytrep.tab1 p

using (

select t.col_A, t.col_B, col_C

from ytrep.tab2 t

) tmp

on (p.col_A= tmp.col_A and p.col_B= tmp.col_B)

when not matched then

insert (col_A, col_B, col_C) values (tmp.col_a, tmp.col_B, tmp.col_C)

when matched then

update set p.col_c = tmp.col_c;

提示:

ORA-30926: 无法在源表中获得一组稳定的行

ORA-30926: unable to get a stable set of rows in the source tables

好了,现在我们来分析为什么会出现这种错误,在ON条件里,我们可以看到p.col_A= tmp.col_A and p.col_B= tmp.col_B,

当tmp表返回记录后,ytrep.tab1取第一条记录 col_a = ‘1’ and col_b = ‘A’ 与tmp表关联时,发现tmp有两条匹配的记录,这时ORACLE就无法判断到底UPDATE SET时应该取TMP表的哪条记录的COL_C值是A1还是A2了,这时ORACLE就返回以上错误;

这时,我们就可以推断,TMP结果集里返回的在ON条件里有涉及字段的值必须是唯一的,否则肯定报以上ORA-30926错误;

这时,有人也许会问,那到底该怎么写呢?

可分为两种情况:

1、一种是通过将TMP表的数据GROUP BY,取得MIN或MAX值;

Merge into ytrep.tab1 p

using (

select t.col_A, t.col_B, max(col_C) col_C –min(col_C) col_C

from ytrep.tab2 t

group by t.col_a, t.col_b

) tmp

on (p.col_A= tmp.col_A and p.col_B= tmp.col_B)

when not matched then

insert (col_A, col_B, col_C) values (tmp.col_a, tmp.col_B, tmp.col_C)

when matched then

update set p.col_c = tmp.col_c;

SQL> select * from ytrep.tab1;

COL_ACOL_BCOL_C

———- ———- ———-

1AA1

2BB1

3CC1

4DD1

5EE2

6FF1

7G

8H

10 HH1

9GG1

10 rows selected

2、一种是分组后再根据某列值排序取第一行或最后一行值;

Merge into ytrep.tab1 p

using (

select distinct t.col_A, t.col_B, first_value(col_c) over (partition by t.col_a, t.col_b order by t.col_d asc) col_c

from ytrep.tab2 t

) tmp

on (p.col_A= tmp.col_A and p.col_B= tmp.col_B)

when not matched then

insert (col_A, col_B, col_C) values (tmp.col_a, tmp.col_B, tmp.col_C)

when matched then

update set p.col_c = tmp.col_c;

SQL> select * from ytrep.tab1;

COL_ACOL_BCOL_C

———- ———- ———-

1AA1

2BB1

3CC1

4DD1

5EE2

6FF1

7G

8H

10 HH1

9GG1

10 rows selected

以上两个SQL,大家可以通过改变order by排序方式对比一下结果。

以上只是本人学习测试结果,如有不同意见或或好的建议,可以留言。谢谢!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。