使用Oracle trunc 来指定精确的年月日时分秒
2014-06-14 14:56
302 查看
转载自:http://wanqiufeng.blog.51cto.com/409430/472103函数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),'yyyy-mm-dd hh24:mi:ss') from dual; 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//截断到月SQL> select trunc(sysdate,'mm') from dual; TRUNC(SYSDATE,'MM')-------------------2010-12-1//截断到日SQL> select trunc(sysdate,'dd') from dual; TRUNC(SYSDATE,'DD')-------------------2010-12-10//截断到小时SQL> select trunc(sysdate,'hh24') from dual; TRUNC(SYSDATE,'HH24')---------------------2010-12-10 20:00:00//截断到分钟SQL> select trunc(sysdate,'mi') from dual; TRUNC(SYSDATE,'MI')-------------------2010-12-10 20:52:00 使用不同的格式标志,可以指示不同的截断位置,获取各种零刻时间。
借助trunc函数和日期类型加减处理,我们可以实现一些特殊日期的设置,实现日期功能,使用在例如Job调度方面。 //明天零点SQL> select to_char(trunc(sysdate)+1,'yyyy-mm-dd hh24:mi:ss') from dual; TO_CHAR(TRUNC(SYSDATE)+1,'YYYY------------------------------2010-12-11 00:00:00 //当天早上十点SQL> select to_char(trunc(sysdate)+10/24,'yyyy-mm-dd hh24:mi:ss') from dual; 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, 'yyyy-mm-dd hh24:mi:ss') from dual;注:trunc(sysdate,'mm')将时间取到当前月的1号零时零分零秒,那么加上2就表示当前月的3好零时零分零秒,再加上'10/24'('10/24'本身表示10个小时)就是表示当月3号的十点零分零秒,再加上'1/48'('1/48'本身表示30分钟)就表示当月3号十点三十分零秒 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//截断到小数点前一位;SQL> select trunc(15.793,-1) from dual; TRUNC(15.793,-1)---------------- 10 trunc对数字和日期类型处理,也折射出日期类型数据和数字之间的间接关系。 原文地址:http://space.itpub.net/17203031/viewspace-681548 trunc不仅可以用来处理日期,还可以用来处理数字TRUNC(i1,i2)截取i1的i2位而不四舍五入,如果i2是正就截取小数点右边第几位,如果是i2是负就是截取小数点左边第几位。例如: select TRUNC(0.10005767,1) from dual; TRUNC(0.10005767,1) 1 0.1而如果trunc函数没有指定参i2,那么其作用为取整,且取整的时候不会四舍五入例如:select TRUNC(2.60005767) from dual; TRUNC(2.60005767)round函数和trunc函数的区别:ROUND(i1,i2)四舍五入,i1四舍五入,如果i2是正保留小数点后i2位。如果是i2是负数,表示保留小数点前面(左边第几位)TRUNC(i1,i2)截取i1的i2位而不四舍五入,如果i2是正就截取小数点右边第几位,如果是i2是负就是截取小数点左边第几位。
格式字符串 | 说明 | |
年 | yyyy或者year | 年度第一天(一月一日零时) |
月 | mm或者month | 月份第一天(一日零时) |
日 | dd或者day | 日期零时(00:00:00) |
小时 | hh或者hh24 | 几时整(XX:00:00) |
分 | mi | 几分整(XX:XX:00) |
相关文章推荐
- 使用Oracle trunc 来指定精确的年月日时分秒
- 使用Oracle trunc 来指定精确的年月日时分秒
- 使用Oracle trunc 来指定精确的年月日时分秒
- 关于Oracle字段类型Date使用mybatis generator自动生成工具出现的查询日期只精确到年月日问题
- oracle优化(一) oracle数据库使用 TIMESTAMP(6)类型保存年月日时分秒
- oracle获取当前年月日时分秒季度周
- oracle获取当前年月日时分秒季度周
- ORACLE查询或删除时指定使用索引的写法
- oracle内置函数 trunc 使用
- ORACLE:关于round和trunc的使用
- 解决:win7 ,64位下,vs 2008 ,oracle 数据库使用内置的web server 报ORA-12154: TNS: 无法解析指定的连接标识符
- C# 版本的 计时器类 精确到微秒 秒后保留一位小数 支持年月日时分秒带单位的输出
- Oracle,mysql使用update替换指定字段里的字符
- 使用oracle的trunc和dbms_random.value随机取n条数据
- zoj 3209 Treasure Map 精确覆盖 DLX 给一些指定位置的矩形,使用最少的矩形去精确覆盖一个大的矩形,矩形间不能重叠。
- oracle函数trunc的使用
- oracle常用三个函数TRIM、TRUNC、DECODE使用体会
- Oracle trunc 使用
- ORACLE查询或删除时指定使用索引的写法­
- VNC指定用户屏幕号登录(Oracle安装时使用)