oracle语句within,oracle语句集锦

1、行转列(PIVOT函数)

语法:

TABLE_SOURCE

PIVOT(聚合函数(value_column) FOR pivot_column IN(< column_list > ))

效果图:

8f4c1282b5980ae6e3485cd6fec0580c.png

d31cafa248bc5c95713a06f2f837e810.png

--行转列select *

fromSalesList pivot(

max(salesNum)for shangPin in ( --shangPin 即要转成列的字段‘上衣‘ as 上衣, --max(salesNum) 此处必须为聚合函数,‘裤子‘ as 裤子, --in() 对要转成列的每一个值指定一个列名‘袜子‘ as袜子,‘帽子‘ as帽子

)

)where 1 = 1;

注意 pivot里面必须使用聚合函数。

2、列转行(UNPIVOT函数)

语法:

TABLE_SOURCE

UNPIVOT(value_column FOR pivot_column IN(< column_list > ))

SELECT * from(SELECT‘罗飞‘STU_NAME,‘2001-2002‘TERM,‘90‘微积分,‘88‘线性代数,‘85‘数据结构,‘70‘操作系统

FROM DUAL) unpivot (scorcefor type in(微积分,线性代数,数据结构,操作系统))

结果:

6f0315df6c05942c727c3727d77ccf8c.png

3、使用  listagg() WITHIN GROUP ()  将多行合并成一行

SELECT

T .DEPTNO,

listagg (T .ENAME,‘,‘) WITHIN GROUP (ORDER BY T .ENAME) names

FROM

SCOTT.EMP T

WHERE

T .DEPTNO= ‘20‘GROUP BY

T .DEPTNO

4、字符串替换(translate函数)

语法:TRANSLATE(char, from, to)

用法:返回将出现在from中的每个字符替换为to中的相应字符以后的字符串。

若from比to字符串长,那么在from中比to中多出的字符将会被删除。

三个参数中有一个是空,返回值也将是空值。

select translate(‘abcdefga‘,‘abc‘,‘wo‘) 返回值 from dual;

返回值:

912294f7fa734c1b874bcca2df4e865c.png

分析:

该语句要将‘abcdefga‘中的‘abc‘转换为‘wo‘,

由于‘abc‘中‘a‘对应‘wo‘中的‘w‘,

故将‘abcdefga‘中的‘a‘全部转换成‘w‘;

而‘abc‘中‘b‘对应‘wo‘中的‘o‘,

故将‘abcdefga‘中的‘b‘全部转换成‘o‘;‘abc‘中的‘c‘在‘wo‘中没有与之对应的字符,

故将‘abcdefga‘中的‘c‘全部删除;

简单说来,就是将from中的字符转换为to中与之位置对应的字符,

若to中找不到与之对应的字符,返回值中的该字符将会被删除。

在实际的业务中,可以用来删除一些异常数据,

比如表a中的一个字段t_no表示电话号码,

而电话号码本身应该是一个由数字组成的字符串,

为了删除那些含有非数字的异常数据,

就用到了translate函数:

SQL> delete from a,

where length(translate(trim(a.t_no),

‘0123456789‘ || a.t_no,

‘0123456789‘)) <> length(trim(a.t_no));

补充:replace也有类似的功能

语法:REPLACE(char, search_string,replacement_string)

用法:将char中的字符串search_string全部转换为字符串replacement_string。

select REPLACE(‘fgsgswsgs‘, ‘fk‘ ,‘j‘) 返回值 from dual;

6214f2af1b91cf9308efcde239b2e7d9.png

select REPLACE(‘fgsgswsgs‘, ‘sg‘ ,‘eeerrrttt‘) 返回值 from dual;

89f8c461687fd2f7ce34f9b181843963.png

分析

分析:第一个例子中由于‘fgsgswsgs‘中没有与‘fk‘匹配的字符串,

故返回值仍然是‘fgsgswsgs‘;

第二个例子中将‘fgsgswsgs‘中的字符串‘sg‘全部转换为‘eeerrrttt‘。

总结:综上所述,replace与translate都是替代函数,

只不过replace针对的是字符串(完全匹配替换),而translate针对的是单个字符(位置匹配替换)。

原文:https://www.cnblogs.com/cq-yangzhou/p/11063473.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值