Oracle计算周同比遇到的坑怎么解决
发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,本篇内容介绍了"Oracle计算周同比遇到的坑怎么解决"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
千家信息网最后更新 2025年02月23日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安全错误
数据库的锁怎样保障安全
asp服务器搭建软件
一卡通数据库配置管理员密码
数据开发软件开发月工资多少
全面筑牢网络安全市财政局
数据库的默认安装路径
搭建web文件管理服务器
网络安全人才缺吗
北京gpu服务器租赁报价
外国的高科技互联网
怀旧服开了多少组服务器
网络安全忧患
泰兴网络技术价格表格
数据库原理与数据库技术
在维普全文数据库中选择作者字段
目前无法连接服务器
中国台湾it软件开发制作
五毛网络技术有限公司
服务器内存套什么定额
分发软件开发网页
csgo 服务器指令
教师网络安全教育讲稿
hive去map中的数据库
高级网络安全系统测评师工信部
青少年网络安全的要点
青岛理工数据库系统
网络安全的防火墙技术
gen8服务器安装系统
核心网络技术支撑难吗
合肥网络技术咨询哪家好
安徽人工智能软件开发报价