【转】Oracle日期类型操作几个问题(二)

前端之家收集整理的这篇文章主要介绍了【转】Oracle日期类型操作几个问题(二)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

转自:

http://blog.itpub.net/17203031/viewspace-681548


函数trunc是一个Oracle内置的函数,可以对date类型数据进行“度身裁剪”,来适应不同类型的数据需求。

在前篇《Oracle日期类型操作几个问题》中,我们已经了解到date类型的基本知识。date类型是一种包括年、月、日、时、分和秒的数据类型,可以表示相对精确的时间信息。内部存储上,date类型是类似于数字类型的,可以通过加减操作实现对日期的推进和后退。

但是,日期格式的精确常常给我们带来一些困扰,特别是其中的时分秒信息。很多时候,我们对这部分信息是不需要的。比如指定日期查询、只显示天信息等等。借助To_char虽然可以实现一部分这种需要,但是这样做格式上比较复杂,而且进行了数据类型的转换。是否存在不变化数据类型的方法,对日期型数据进行处理。答案就是trunc函数

trunc(date)

截断函数trunc的作用就是将日期类型数据按照指定格式截断,返回一个日期变量数据。例如:

sql> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

TO_CHAR(SYSDATE,'YYYY-MM-DDHH2

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

2010-12-10 20:39:58

sql> select trunc(sysdate) from dual;

TRUNC(SYSDATE)

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

2010-12-10

sql> select to_char(trunc(sysdate),102);background:#C0C0C0;">TO_CHAR(TRUNC(SYSDATE),'YYYY-M

2010-12-10 00:00:00

默认情况下,sysdate函数返回的日期类型数据包括当前的具体时间。通过trunc(date)的处理,直接截取到天信息,返回指定天的零时。

trunc函数支持一个重载参数,格式字符串:trunc(date,format),用于指定截断的位置。如下:

//截断到年

sql> select trunc(sysdate,'yyyy') from dual;

TRUNC(SYSDATE,'YYYY')

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

2010-1-1

//截断到月

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

2010-12-1

//截断到日

//截断到小时

2010-12-10 20:00:00

//截断到分钟

2010-12-10 20:52:00

使用不同的格式标志,可以指示不同的截断位置,获取各种零刻时间。

格式字符串

说明

yyyy或者year

年度第一天(一月一日零时)

mm或者month

月份第一天(一日零时)

dd或者day

日期零时(00:00:00)

小时

hh或者hh24

几时整(XX:00:00)

mi

几分整(XX:XX:00)

借助trunc函数和日期类型加减处理,我们可以实现一些特殊日期的设置,实现日期功能,使用在例如Job调度方面。

//明天零点

sql> select to_char(trunc(sysdate)+1,102);background:#C0C0C0;">TO_CHAR(TRUNC(SYSDATE)+1,'YYYY

2010-12-11 00:00:00

//当天早上十点

sql> select to_char(trunc(sysdate)+10/24,102);background:#C0C0C0;">TO_CHAR(TRUNC(SYSDATE)+10/24,'

2010-12-10 10:00:00

//当月三号,上午10点半

sql> select to_char(trunc(sysdate,'mm')+2+10/24+1/48,102);background:#C0C0C0;">TO_CHAR(TRUNC(SYSDATE,'MM')+2+

2010-12-03 10:30:00

较复杂的to_char,trunc更加可以发挥日期类型数值本身的特色和优势,无论是代码整洁度还是处理效率都是值得关注的。

额外多说一句,trunc本身还具有处理数字截断功能,用于截断指定位数的数字类型。

//默认截断到整数,不进行四舍五入;

sql> select trunc(15.743) from dual;

TRUNC(15.743)

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

15

//截断到小数点后一位;

sql> select trunc(15.793,1) from dual;

TRUNC(15.793,1)

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

15.7

//截断到小数点前一位;

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

10

trunc对数字和日期类型处理,也折射出日期类型数据和数字之间的间接关系。

猜你在找的Oracle相关文章