当前位置: 首页 > article >正文

oracle 四舍五入日期,Oracle时间运算(日期截取及四舍五入)

Oracle时间运算(日期截取及四舍五入) 如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途: ROUND(date [, format]) TRUNC(d

Oracle时间运算(日期截取及四舍五入)  如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:

ROUND(date [, format])

TRUNC(date [, format])

Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。

二、Round和Trunc函数示例:

SQL> select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') now_date,

2 to_char(Round(sysdate),'yyyy-mm-dd hh24:mi:ss') round_date,

3 to_char(Trunc(sysdate),'yyyy-mm-dd hh24:mi:ss') trunc_date

4 from dual;

NOW_DATE ROUND_DATE TRUNC_DATE

-------------------------------------- -------------------------------------- ----------------------

2008-06-30 14:52:13 2008-07-01 00:00:00 2008-06-30 00:00:00

这是一个典型的例子,由于我们没有指定round和trunc函数的格式,所以Oracle默认采用了按日期时间的 格式,该例子中当前的时间是下午14:52分,已经超过了12:00 AM这个中界线,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。

另外一个值得注意的地方是这两个函数返回的时分秒都是00:00:00,即一天的开始时间(对于12小时制的返回的是12:00:00 AM)。

三、指定格式的Round和Trunc函数示例:

如果我们对Round函数和Trunc函数指定了格式,事情就变得有点复杂了,不过核心思想还是不变:Round是 四舍五入,Trunc是截取。举个例子来说,假如我们以年为格式,则现在Oracle的判断是基于年来判断,超过一年的一半(即6月30日),Round 函数则返回下一年了,Trunc函数依然返回当前年。

SQL> select sysdate "Now date",

2 Round(sysdate, 'yyyy') Round_year,

3 Trunc(sysdate, 'yyyy') Trunc_year

4 from dual;

Now date ROUND_YEAR TRUNC_YEAR

---------- ---------- ----------

30-6月 -08 01-1月 -08 01-1月 -08

关于这两个函数可用的格式非常多,但日常应用中用得比较多的基本上就这几个,以Round函数为例:

select Round(sysdate, 'Q') Rnd_Q,

Round(sysdate, 'Month') Rnd_Month,

Round(sysdate, 'WW') Rnd_Week,

Round(sysdate, 'W') Rnd_Week_again,

Round(sysdate, 'DDD') Rnd_day,

Round(sysdate, 'DD') Rnd_day_again,

Round(sysdate, 'DAY') Rnd_day_of_week,

Round(sysdate, 'D') Rnd_day_of_week_again,

Round(sysdate, 'HH12') Rnd_hour_12,

Round(sysdate, 'HH24') Rnd_hour_24,

Round(sysdate, 'MI') Rnd_minute

from dual

http://www.lryc.cn/news/2419852.html

相关文章:

  • 浅谈synchronized、wait、notify和notifyAll
  • 快速傅里叶变换(蝶形算法c++源代码)
  • 对象类Android应用程序资源管理器(Asset Manager)的创建过程分析
  • 台大郭彦甫MATLAB学习笔记(Part1)
  • [Other]规范的邮件签名格式及HTML代码
  • 推荐几款网页截图工具可以全屏截图,也可对图片编辑
  • 博客系统(Java+MySQL)
  • DelPhi学习网站
  • 1.注册msn邮箱 2.使用MSN
  • scanf的用法大全
  • 迭代式开发
  • 什么是标记语言
  • 配置管理漫漫谈之典型配置库结构
  • 如何用python爬取e-hentai的图片
  • 卷积
  • linetv_line tv官方下载-line tv 安卓版v2.0.0-PC6安卓网
  • history详解
  • 彩色模型,及RGB,CMY,CMYK,HSI,CIE,YIQ,YUV相互转化及介绍
  • 统一网关Gateway介绍和使用
  • 段码液晶屏点亮思路--以华大单片机为例
  • 总线/通信笔记3 —— PDO与SDO的区别
  • MRTG安装教程
  • Git和ClearCase优缺点比较
  • showModalDialog 使用详解
  • C#制作一个四舍五入
  • 史上最详细Oracle 10g安装教程
  • switch case语句语法
  • 芯龙DC-DC电源管理芯片
  • Java (计算机编程语言)
  • 电子电路学习笔记(17)——蜂鸣器