Oracle中补全时间的处理

在实际数据处理的过程中,存在日期不连续的问题,可能会导致数据传到前后端出现异常,为了避免这种问题,通常会从数据端进行日期不全的处理:

以下为补全年份的案例:

sql 复制代码
with x as
(select 开始年份 +(level-1)as 年份 
 from(select extract①(YEAR from min(hiredate))as 开始年份.
             extract(YEAR from max(hiredate))as 结束年份
      from emp)
connect by② level③ <= 结束年份 - 开始年份 + 1
)
select * from x;

1、extract函数:用于从时间中提取特定部分,如年月日时分秒,语法:extract(field from source) ;

field:YEAR、MONTH、DAY、HOUR、MINUTE、SECOND等

source:日期或时间值,列名、表达式、常量;

2、connect by:树形查询关键词,此处用于生成数字序列结果集;

3、level:此处用于限制查询结果的行数,这里可以换成rownum,区别在于level用于树形查询的节点,若有相同层级时level相同,rownum用于普通查询,不会出现重复值。

相关推荐
gugugu.18 分钟前
Redis Set类型完全指南:无序集合的原理与应用
数据库·windows·redis
wang60212521841 分钟前
为什么不采用级联删除而选择软删除
数据库·oracle
变形侠医2 小时前
比 Kettle 快2倍的 Java ETL 开源库:Etl-engine
数据库
soft20015252 小时前
从一次增删改操作开始:彻底理解 MySQL Buffer Pool 的地位与作用
数据库·mysql
feathered-feathered2 小时前
Redis基础知识+RDB+AOF(面试)
java·数据库·redis·分布式·后端·中间件·面试
whm27772 小时前
Visual Basic 建立数据库
开发语言·数据库·visual studio
檀越剑指大厂3 小时前
【数据库系列】倒排索引(Inverted Index)
数据库·inverted-index
闲人编程3 小时前
权限系统设计与RBAC实现
java·网络·数据库·rbac·权限·codecapsule
花月C3 小时前
基于Redis的BitMap数据结构实现签到业务
数据结构·数据库·redis
hgz07103 小时前
数据库事务
数据库·mysql