ORACLE常用函数

       最近工作上在做工作流的一个物流系统,遇到了挺多Oracle Sql的查询,突然感觉自己的SQL语句很差啊,连基本的查询语句都不会了,今天看会原来在项目中用到的SQL查询语句,总结记录一下。

Oracle大师Thomas Kyte在他的经典著作中,反复强调过一个实现需求方案选取顺序:

“如果你可以使用一句SQL解决的需求,就使用一句SQL;如果不可以,就考虑PL/SQL是否可以;如果PL/SQL实现不了,就考虑Java存储过程是否可以;如果这些都不可能实现,那么就需要考虑你是否真的需要实现这个需求。”

读了句话,现在想想,这句话说得还是很有道理的。当遇到一个需求的时候,首先考虑的是一条SQL,然后再到PL/SQL,最后才是Java,如果都不行,那这个需求还是不要实现了吧!

好了,本文介绍三个日常开发中经常用到的ORACLE函数:

以ORACLE  SCOTT用户为例做演示SQL语句

1、listagg

我们有时会遇到这样一种需求:对员工列表进行操作,要求将员工姓名横向排列为一列,以逗号进行分割每个员工名称。

这时候我们就可以用到listagg函数了,请看具体用法:


select listagg(e.ename,',') within group (order by e.ename) as names  from emp e

结果集:



2.lag函数:获取上个月的信息

有时我们需要统计今个月和上个月(或者今年和上一年)的某些信息时就可以时候lag函数了


-- 获取上一个月的销售金额  lag函数:用法select lag(列名,1) over (order by month) form 表名
select month,qual,lag(qual,1) ignore nulls over (order by month) from sales_qual order by month

请看结果集:


3.lead函数:获取下一个月的某些信息

有时我们需要统计下一个月(或者下一年)的某些信息时就可以时候lead函数了


select month,lead(qual,1) ignore nulls over (order by month) from sales_qual order by month

结果集是:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Seven的代码实验室

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值