首页 > 数据库技术 > 详细

oracle语句集锦

时间:2019-06-21 13:51:55      阅读:137      评论:0      收藏:0      [点我收藏+]

1、行转列(PIVOT函数)

语法:

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

效果图:

技术分享图片技术分享图片

--行转列
select *
  from SalesList 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 (scorce for type in(微积分,线性代数,数据结构,操作系统))

结果:

技术分享图片

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;

返回值:

技术分享图片

分析:

该语句要将abcdefga中的abc转换为wo,
            由于abca对应wo中的w,
            故将abcdefga中的a全部转换成w;
            而abcb对应wo中的o,
            故将abcdefga中的b全部转换成o;
            abc中的cwo中没有与之对应的字符,
            故将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;

技术分享图片

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

技术分享图片

分析

分析:第一个例子中由于fgsgswsgs中没有与fk匹配的字符串,
            故返回值仍然是fgsgswsgs;
            第二个例子中将fgsgswsgs中的字符串sg全部转换为eeerrrttt。
总结:综上所述,replace与translate都是替代函数,
         只不过replace针对的是字符串(完全匹配替换),而translate针对的是单个字符(位置匹配替换)。

 

oracle语句集锦

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!