Oracle计算周同比遇到的坑怎么解决
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,本篇内容介绍了"Oracle计算周同比遇到的坑怎么解决"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
千家信息网最后更新 2025年12月01日Oracle计算周同比遇到的坑怎么解决
本篇内容介绍了"Oracle计算周同比遇到的坑怎么解决"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
系统环境:windows2008 Oracle 10g
报表的需求是,要求对数据进行按周的同比,比如2021年1月1日是周五,那么同比日期就要求也必须是周五,即为2020年1月3日,以此类推。
我的办法是,根据当前日期,先取到同比的年份,再取当前日期是全年的第几周,最后取是周中的第几天。
最初的SQL语句写法:
WHERE 日期 >= ( SELECT 日期字段 FROM 某张表 WHERE TO_CHAR(日期字段, YYYY')= TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12),'YYYY') AND TO_CHAR(日期字段, 'd')=( SELECT TO_CHAR(TRUNC(SYSDATE-1, 'mm'), 'd') FROM dual) AND TO_CHAR(日期字段-1, 'ww')=( SELECT TO_CHAR(TRUNC(SYSDATE-1, 'mm'), 'ww') FROM dual)) AND 日期 <=( SELECT 日期字段 FROM 某张表 WHERE TO_CHAR(日期字段, 'YYYY')= TO_CHAR(ADD_MONTHS(SYSDATE-1,-12),'YYYY') AND TO_CHAR(日期字段, 'd')=( SELECT TO_CHAR(SYSDATE-1, 'd') FROM dual) AND TO_CHAR(日期字段-1, 'ww')=( SELECT TO_CHAR(SYSDATE-1, 'ww') FROM dual))
然后坑就出现了,2021年1月14日Oracle to_char函数计算的全年周数是2,到15日计算的全年的周数就变成3了,明明是一周,可是周数却不同。
经过反复排查和询问度娘,才了解了Oracle关于标准周的定义方式,是以每年1月1日的星期为全年周的起始日,不管这一天是周几,2021年1月1日是星期五,那么所有的标准周都是以星期五开始计算的。
根据Oracle的这个奇怪规定,用两个年份1月1日的星期相减,来修正误差。
DECODE( SIGN(TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd')), 0, 0, 1, TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd'), -1, 7-ABS(TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd') ))
修正后的SQL语句写法
WHERE 日期 >= ( SELECT 日期字段 FROM 某张表 WHERE TO_CHAR(日期字段, YYYY')= TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12),'YYYY') AND TO_CHAR(日期字段, 'd')=( SELECT TO_CHAR(TRUNC(SYSDATE-1, 'mm'), 'd') FROM dual) AND TO_CHAR(日期字段-1, 'ww')=( SELECT TO_CHAR(TRUNC(SYSDATE-1, 'mm'), 'ww') FROM dual)) AND 日期 <=( SELECT 日期字段 FROM 某张表 WHERE TO_CHAR(日期字段, 'YYYY')= TO_CHAR(ADD_MONTHS(SYSDATE-1,-12),'YYYY') AND TO_CHAR(日期字段, 'd')=( SELECT TO_CHAR(SYSDATE-1, 'd') FROM dual) AND TO_CHAR(日期字段-(DECODE(SIGN(TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd')), 0, 0, 1, TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd'),-1, 7-ABS(TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd')))), 'ww')=( SELECT TO_CHAR(SYSDATE-(DECODE(SIGN(TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd')), 0, 0, 1, TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd'),-1, 7-ABS(TO_CHAR(TRUNC(SYSDATE, 'yy'), 'd')-TO_CHAR(ADD_MONTHS(TRUNC(SYSDATE-1, 'mm'),-12), 'd')))), 'ww') FROM dual))
"Oracle计算周同比遇到的坑怎么解决"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
日期
字段
全年
星期
内容
写法
年份
更多
标准
知识
语句
不同
实用
以此类推
学有所成
接下来
两个
函数
办法
困境
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全管理征求意见
安徽电商外贸软件开发
奥的斯用服务器呼梯方法
电子商务网络安全威胁
域文件服务器资源管理器
爱拉拉软件开发
学习网络安全专业课程有哪些
软件开发需要的网络知识
传感网络技术在军事上的应用
视频存储数据库mysql
网易服务器bug大全
软件开发公司旺季
服务器和客户端通信
青岛智路软件开发有限公司
肇庆esop软件开发
实时数据库系统更新画面
网络安全主题名
数据库缓存方案设计
怎么用js连接数据库
计算机网络技术到底是学啥的
数据库中全角 半角
电脑连接wifi服务器异常
3ds服务器关闭了吗
数据库open与execute
怎么关闭云服务器升级
企业邮箱软件服务器
蓟州区项目网络技术不二之选
嵌入式 软件开发 创业
网络安全和软件开发职业
网络安全事关国家网络主权