ORACLE单张表逐年比较某个字段是否增加打上标识

lou3578 2019-04-02 03:25:10
SOS
...全文
110 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
nayi_224 2019-04-04
  • 打赏
  • 举报
回复
分析函数、层次查询、递归with、model、自连接、标量子查询、存储过程都可以实现,考虑到效率,后三个不予考虑,考虑到简易程度,分析函数是首选。
AHUA1001 2019-04-04
  • 打赏
  • 举报
回复
引用 6 楼 qq_40175369 的回复:
[quote=引用 5 楼 AHUA1001的回复:]SELECT t.*,
(SELECT DECODE(COUNT(0),0,'未增加','增加') FROM table_name tt WHERE tt.name = t.name AND tt.nd - 1 = t.nd AND (tt.lhq < t.lhq OR tt.ck < t.ck OR tt.sfq < t.sfq)) z
FROM table_name t ORDER BY t.name,t.nd ;

谢谢 我也试了试你这个 好像出不来 …[/quote]
加索引name +nd
大脸猫o 2019-04-03
  • 打赏
  • 举报
回复
抛砖引玉吧,我觉得这个提问的重点是位置偏移函数的使用,lag,lead 还有一个比较复杂的我也没记住 好几个关键字的
with t as
(select '小明' name, 0 lhq, 1 ck, 0 sfq, 2015 nd
from dual
union all
select '小明' name, 0 lhq, 1 ck, 0 sfq, 2016 nd
from dual
union all
select '小明' name, 1 lhq, 1 ck, 2 sfq, 2017 nd
from dual
union all
select '小明' name, 1 lhq, 2 ck, 1 sfq, 2018 nd
from dual
union all
select '小明' name, 3 lhq, 0 ck, 0 sfq, 2019 nd
from dual)
select m.*,
case
when lhq > lhq or ck > ck_next or sfq > sfq_next then
'增加'
else
'未增加'
end as flag
from (select name,
lhq,
lag(lhq) over(order by nd) lhq_next,
ck,
lag(ck) over(order by nd) ck_next,
sfq,
lag(sfq) over(order by nd) sfq_next,
nd
from t) m
lou3578 2019-04-03
  • 打赏
  • 举报
回复
引用 5 楼 AHUA1001的回复:
SELECT t.*,
(SELECT DECODE(COUNT(0),0,'未增加','增加') FROM table_name tt WHERE tt.name = t.name AND tt.nd - 1 = t.nd AND (tt.lhq < t.lhq OR tt.ck < t.ck OR tt.sfq < t.sfq)) z
FROM table_name t ORDER BY t.name,t.nd ;
谢谢 我也试了试你这个 好像出不来 …
AHUA1001 2019-04-03
  • 打赏
  • 举报
回复
SELECT t.*,
(SELECT DECODE(COUNT(0),0,'未增加','增加') FROM table_name tt WHERE tt.name = t.name AND tt.nd - 1 = t.nd AND (tt.lhq < t.lhq OR tt.ck < t.ck OR tt.sfq < t.sfq)) z
FROM table_name t ORDER BY t.name,t.nd ;
lou3578 2019-04-02
  • 打赏
  • 举报
回复
出来了 万分感谢 感谢【2
nayi_224 2019-04-02
  • 打赏
  • 举报
回复
case when lhp > lag(lhp) over(partition by name order by nd) or
lhp > lag(ck) over(partition by name order by nd) or
lhp > lag(sfq) over(partition by name order by nd)
then '增加'
else '' end
lou3578 2019-04-02
  • 打赏
  • 举报
回复
引用 1 楼 yaiger的回复:
把lhq+ck+sfq的和做比较
能不能写个例子 大佬 我还是个萌新 万分感谢 sum可以的 但是 不会写…
yaiger 2019-04-02
  • 打赏
  • 举报
回复
把lhq+ck+sfq的和做比较
课程简介:Oracle 11G 完整的课程体系,从安装到入门到项目实战开发,整个学习过程,都以实践操作为主,大量的案例,实例,作业,来保证学习,练习,直到具备数据分析师,掌握SQL部分,能达到数据库开发工程师的能力要求与水平,SQL查询,数据库对象,索引,视图,分区,优化等等实现从事数据分析师所具备的的数据处理能力,结合存储过程开发与使用,能更好的结合业务需求来完成对指标的统计与分析。 课程收益你将获得:    数据分析师SQL实战    掌握Oracle数据库全部技能    数据分析师入门操作    数据库开发工程师    独立开发数据库需求    SQL纯实战应用    具备数据处理,数据存储技能    具备数据仓库架构师思维与应用 1、建议每天保证2个小时学习时间,加以练习实操2、每节课后的练习案例动手实践,方能记忆深刻3、学完知识点后举一反三,应用到实际工作中 课程亮点:Oracle全集包含服务器搭建,客户端使用,入门步骤,SQL各查询实现,条件查询,分组,聚合函数,正则达式,高级函数,连接查询,多查询,子查询,数据插入,更新,删除,数据库对象,如,视图,索引,同义词,分区,存储过程,存储过程大量案例,项目开发等等内容丰富,各知识点都配置相应的作业及解答过程,真正实例与案例操作,学会Oracle各种操作,满足实际业务工作需要,真正做到事半功倍,以实践工作出发完成各知识点的学习与应用,掌握数据库相关的技能 适合人群: 数据分析师,数据库开发人员,技能提升,数据库应用,在校学生,零基础入门,项目开发,初,中,高级数据库开发工 程师,ETL开发,数据仓库架构,数据运维,企业开发,数据管理,数据质量等。 老师介绍:SUN老师高级数据分析专家,有着丰富的BI项目开发工作经验,具备数仓各方面的数据治理,指标开发,业务梳理,口径开发,曾相继在中国移动,亚信,文思任职高级项目开发,专业领域BI,数据分析,维度与指标展示,数仓流程开发,可视化等相关技术 ,有完备的数据分析理论知识与应用,在数据分析,数据处理,数据可视化数据建模等应用,指标统计,维度分析,多维分析等有深入研究,具备更严谨的实践技能操作。 课程大纲:

3,491

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 高级技术相关讨论专区
社区管理员
  • 高级技术社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧