ITPub博客

首页 > Linux操作系统 > Linux操作系统 > Oracle分析函数

Oracle分析函数

原创 Linux操作系统 作者:husthxd 时间:2006-09-05 00:00:00 0 删除 编辑

oracle的分析函数功能很强,略举一例,需求如下:

有表t1:

......................

ywbh char(16),-- 业务编号

bh char(10),-- 编号

clrq char(8),-- 处理日期

........................

有两类业务:增加业务和减少业务,业务编号分别以ZJ和JS开头,clrq用于记录业务处理日期(增加、减少)。如何获取同一编号bh的最大增加日期和最大减少日期?


使用max:

select
distinct bh,
max(case when substr(ywbh,1,2) ='ZY' THEN clrq else null end) over(partition by bh) zjrq_max,
max(case when substr(ywbh,1,2) ='JY' THEN clrq else null end) over(partition by bh) jsrq_max
from t1;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/6906/viewspace-22076/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 10g启用归档出错
请登录后发表评论 登录
全部评论
ITPUB数据库版块资深版主,对Oracle、PostgreSQL有深入研究。

注册时间:2007-12-28

  • 博文量
    1397
  • 访问量
    3842279