我们的文章会在微信公众号IT民工的龙马人生和博客网站( www.htz.pw )同步更新 ,欢迎关注收藏,也欢迎大家转载,但是请在文章开始地方标注文章出处,谢谢!
由于博客中有大量代码,通过页面浏览效果更佳。
本文为个人学习《Expert Oracle Database Architecture Techniques and Solutions for High Performance and Productivity(第四版本》一书过程中的笔记与理解分享,仅用于学习与交流,部分内容参考原书观点并结合>实际经验进行整理。若涉及版权问题,请联系删除或沟通处理。也请大家支持购买原版书籍。
时间间隔类型:轻松管理时长与时间点
在日常数据库操作中,我们经常需要处理时间间隔或持续时间。Oracle数据库提供了两种非常实用的时间间隔类型,让时间计算变得简单直观。
两种时间间隔类型
-
年月至月间隔(YEAR TO MONTH)
- 适合存储以年和月为单位的时间段
- 比如:2年6个月、5年11个月
-
天至秒间隔(DAY TO SECOND)
- 适合存储更精确的时间段
- 包含天、小时、分钟、秒,甚至小数秒
- 比如:10天2小时3分2.3312秒
实用技巧:提取时间信息
假设我们要计算两个时间点之间的间隔:
-- 计算2000年2月29日与2001年3月15日之间的时间差
SELECT dt2 - dt1 AS 时间间隔
FROM (SELECT TO_TIMESTAMP('2000-02-29 01:02:03.122', 'YYYY-MM-DD HH24:MI:SS.FF') AS dt1,TO_TIMESTAMP('2001-03-15 11:22:33.000', 'YYYY-MM-DD HH24:MI:SS.FF') AS dt2FROM dual
)
得到结果:380天10小时20分29.878秒
使用EXTRACT函数可以轻松提取各个时间单位:
SELECT EXTRACT(DAY FROM dt2-dt1) AS 天数,EXTRACT(HOUR FROM dt2-dt1) AS 小时,EXTRACT(MINUTE FROM dt2-dt1) AS 分钟,EXTRACT(SECOND FROM dt2-dt1) AS 秒数
创建时间间隔的简单方法
- 创建年月间隔
-- 5年2个月
SELECT NUMTOYMINTERVAL(5, 'YEAR') + NUMTOYMINTERVAL(2, 'MONTH') FROM dual;-- 或者更简单的方法
SELECT NUMTOYMINTERVAL(5*12 + 2, 'MONTH') FROM dual;
- 创建天秒间隔
-- 10天2小时3分2.3312秒
SELECT NUMTODSINTERVAL(10, 'DAY') +NUMTODSINTERVAL(2, 'HOUR') +NUMTODSINTERVAL(3, 'MINUTE') +NUMTODSINTERVAL(2.3312, 'SECOND')
FROM dual;
实际应用场景
-
存储具体时间点
- 比如只需要存储"早上8点"这样的时间
- 使用DAY TO SECOND类型非常合适
-
计算工龄
- 用YEAR TO MONTH类型计算员工工作年限
- "3年8个月"这样的表示很直观
-
精确计时
- 体育比赛计时、实验时间记录等
- 使用DAY TO SECOND类型可以精确到小数秒
简单易用的替代方法
除了使用函数,还可以直接书写:
-- 直接写时间间隔
SELECT INTERVAL '5-2' YEAR TO MONTH FROM dual; -- 5年2个月
SELECT INTERVAL '10 02:03:02.3312' DAY TO SECOND FROM dual; -- 10天2小时3分2.3312秒
总结
时间间隔类型让时间计算变得:
- ✅ 更直观:直接看到年、月、天、时、分、秒
- ✅ 更精确:支持小数秒级精度
- ✅ 更简单:内置函数让计算变得轻松
- ✅ 更灵活:满足各种时间存储和计算需求
无论你是需要计算两个日期之间的差异,还是需要存储特定的时间点,这些时间间隔类型都能提供简单而强大的解决方案。下次处理时间相关数据时,不妨试试这些实用的功能!
------------------作者介绍-----------------------
姓名:黄廷忠
个人博客: (http://www.htz.pw)
CSDN地址: (https://blog.csdn.net/wwwhtzpw)
博客园地址: (https://www.cnblogs.com/www-htz-pw)