【转】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 使用不同的格式标志,可以指示不同的截断位置,获取各种零刻时间。
|