oracle sql--计算某一日期到当前日期的间隔天数

oracle sql--计算某一日期到当前日期的间隔天数

如题,是在工作中遇到的一个报表需求问题。用户需要查询"创建时间到当下的天数",于是我这个可怜的打工仔就开始干活了。。。(苦涩ing)我发现oracle sql的自带函数和普通的sql貌似还有些不大一样,有点不通用呢

首先,要解决获取系统当前时间--to_char()

sql 复制代码
to_char(sysdate,'yyyy/mm/dd hh24:mi:ss')

这个函数的时间格式大家可以随意调整,根据自己的需求灵活变更即可。

以下是一部分时间格式的举例

sql 复制代码
 select sysdate,to_char(sysdate,'yyyy-mm-dd')from dual;
 select sysdate,to_char(sysdate,'yyyy/mm/dd')from dual;
 select sysdate,to_char(sysdate,'yyyymmdd')from dual;
 select sysdate,to_char(sysdate,'yyyymmdd hh24:mi:ss')from dual;

第二,完成间隔天数的计算--用减法即可

sql 复制代码
to_date(to_char(sysdate,'yyyy/mm/dd hh24:mi:ss'),'yyyy/mm/dd hh24:mi:ss')-to_date('2024/05/19 23:54:35','yyyy/mm/dd hh24:mi:ss')

为方便我用了'2024/05/19 23:54:35'这个固定时间举例,大家可以按需替换成对应格式的参数字段

最后,我还需要将计算结果保留两位小数--TRUNC()

sql 复制代码
TRUNC('参数',number)
select TRUNC(to_date(to_char(sysdate,'yyyy/mm/dd hh24:mi:ss'),'yyyy/mm/dd hh24:mi:ss')-to_date('2024/05/19 23:54:35','yyyy/mm/dd hh24:mi:ss'),2) from dual;

'参数'为原数据,number是保留的小数位数

...

以上仅代表个人见解,如有更好的方法或者大家发现我有错误的地方,欢迎在评论区做补充哦~

相关推荐
2501_941805936 小时前
在大阪智能零售场景中构建支付实时处理与高并发顾客行为分析平台的工程设计实践经验分享
数据库
李慕婉学姐6 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
珠海西格电力6 小时前
零碳园区有哪些政策支持?
大数据·数据库·人工智能·物联网·能源
数据大魔方7 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
Chasing Aurora7 小时前
数据库连接+查询优化
数据库·sql·mysql·prompt·约束
倔强的石头_7 小时前
【金仓数据库】ksql 指南(六)—— 创建与管理用户和权限(KingbaseES 安全控制核心)
数据库
小熊officer8 小时前
Python字符串
开发语言·数据库·python
渐暖°9 小时前
JDBC直连ORACLE进行查询
数据库·oracle
萧曵 丶9 小时前
Next-Key Lock、记录锁、间隙锁浅谈
数据库·sql·mysql·mvcc·可重复读·幻读
做cv的小昊10 小时前
【TJU】信息检索与分析课程笔记和练习(7)数据库检索—Ei
数据库·笔记·学习·全文检索