Oracle查询优化日期运算实例详解

 更新时间:2017年05月15日 10:12:57   投稿:lqh  
这篇文章主要介绍了Oracle查询优化日期运算实例详解的相关资料,需要的朋友可以参考下

 加减日、月、年

在Oracle中,date类型可以直接加减天数,而加减月份要用add_months函数.

select a.hiredate 雇用日期,
    a.hiredate + 5 加5天,
    a.hiredate - 5 减5天,
    add_months(hiredate, 5) 加5个月,
    add_months(hiredate, -5) 减5个月,
    add_months(hiredate, 5 * 12) 加5年,
    add_months(hiredate, -5 * 12) 减5年
 from emp a where rownum <=1;


雇用日期 加5天 减5天 加5个月 减5个月 加5年 减5年
----------- ----------- ----------- ----------- ----------- ----------- -----------
1980-12-17 1980-12-22 1980-12-12 1981-05-17 1980-07-17 1985-12-17 1975-12-17

加减时、分、秒

上面讲过,date可以直接加减天数,那么1/24就是一小时,分钟与秒的加减类同。

select a.hiredate,
    a.hiredate - 5 / 24 / 60 / 60 减5秒,
    a.hiredate + 5 / 24 / 60 / 60 加5秒,
    a.hiredate - 5 / 24 / 60 减5分钟,
    a.hiredate + 5 / 24 / 60 加5分钟,
    a.hiredate - 5 / 24 减5小时,
    a.hiredate + 5 / 24 加5小时
 from emp a
 where rownum <= 1;

如果执行时,报错

杩欓噷鍐欏浘鐗囨弿杩? title=

数据库服务器端的编码和客户端字符集编码不一致。

我这边用的数据库西班牙语,不支持中文。

日期间隔之时、分、秒

SQL> select duration,
    duration * 24 间隔小时,
    duration * 24 * 60 间隔分钟,
    duration * 24 * 60 * 60 间隔秒
 from (select (max(a.hiredate) - min(a.hiredate)) as duration from emp a where
    a.ename in ('ALLEN', 'WARD')) x;


 DURATION    间隔小时    间隔分钟    间隔秒
---------- ---------- ---------- ----------
     2     48    2880   172800

日期间隔之日、月、年

加减月份用函数 add_months, 而计算月份间隔就要用函数months_between

select max_hd - min_hd 间隔天,
    months_between(max_hd, min_hd) 间隔月,
    months_between(max_hd, min_hd) /12 间隔年
 from (select min(hiredate) min_hd, max(hiredate) max_hd from emp) x;


    间隔天    间隔月    间隔年
---------- ---------- ----------
   2348 77.1935483 6.43279569

计算一年中周内各日期的次数

问题

计算一年中周内各日期(星期日、星期一 ……星期六)的次数。

解决方案

要计算一年中周内各日期分别有多少个,必须:

  1. 生成一年内的所有日期。
  2. 设置日期格式,得到每个日期对应为星期几。
  3. 计数周内各日期分别有多少个。
with x as
 (select level lvl
  from dual
 connect by level <=
       (add_months(trunc(sysdate, 'y'), 12) - trunc(sysdate, 'y')))
select to_char(trunc(sysdate, 'y') + lvl - 1, 'DAY'), count(*)
 from x
 group by to_char(trunc(sysdate, 'y') + lvl - 1, 'DAY');

杩欓噷鍐欏浘鐗囨弿杩? title=

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Oracle7.X 回滚表空间数据文件误删除处理方法

    Oracle7.X 回滚表空间数据文件误删除处理方法

    Oracle7.X 回滚表空间数据文件误删除处理方法...
    2007-03-03
  • oracle中添加删除主键的方法

    oracle中添加删除主键的方法

    这篇文章主要介绍了oracle中添加删除主键的方法,需要的朋友可以参考下
    2017-01-01
  • 教你怎样用Oracle方便地查看报警日志错误

    教你怎样用Oracle方便地查看报警日志错误

    由于报警日志文件很大,而每天都应该查看报警日志(查看有无“ORA-”,Error”,“Failed”等出错信息),故想找到一种比较便捷的方法,查看当天报警日志都有哪些错误。
    2014-08-08
  • oracle使用sql脚本生成csv文件案例学习

    oracle使用sql脚本生成csv文件案例学习

    在oracle中用sql脚本生成csv文件,很多的朋友都想实现这样的功能,所以本文的出现是很有必要的,感兴趣的你可千万不要错过,希望本文可以帮助到你
    2013-02-02
  • Oracle中NEXTVAL案例详解

    Oracle中NEXTVAL案例详解

    这篇文章主要介绍了Oracle中NEXTVAL案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 运行在容器中的Oracle XE-11g

    运行在容器中的Oracle XE-11g

    今天小编就为大家分享一篇关于运行在容器中的Oracle XE-11g,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • 使用PLSQL远程连接Oracle数据库的方法(内网穿透)

    使用PLSQL远程连接Oracle数据库的方法(内网穿透)

    Oracle数据库来源于知名大厂甲骨文公司,是一款通用数据库系统,能提供完整的数据管理功能,而Oracle数据库时关系数据库的典型代表,其数据关系设计完备,这篇文章主要介绍了使用PLSQL远程连接Oracle数据库的方法(内网穿透),需要的朋友可以参考下
    2023-03-03
  • oracle scott 解锁步骤

    oracle scott 解锁步骤

    本节主要介绍了oracle scott 解锁的具体步骤,需要的朋友可以参考下
    2014-07-07
  • Oracle function函数返回结果集的3种方法

    Oracle function函数返回结果集的3种方法

    工作中常需要经过一段复杂逻辑处理后,得出的一个结果集,所以这篇文章主要给大家介绍了关于Oracle function函数返回结果集的3种方法,需要的朋友可以参考下
    2023-07-07
  • oracle用户权限管理使用详解

    oracle用户权限管理使用详解

    这篇文章主要介绍了oracle用户权限管理使用方法,需要的朋友可以参考下
    2014-04-04

最新评论