函数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

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

格式字符串

说明

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,'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对数字和日期类型处理,也折射出日期类型数据和数字之间的间接关系。

trunc oracle month,使用Oracle trunc 来指定精确的年月日时分秒相关推荐

  1. oracle trunc年,使用Oracle trunc 来指定精确的年月日时分秒

    函数trunc是一个Oracle内置的函数,可以对date类型数据进行"度身裁剪",来适应不同类型的数据需求. 在前篇<Oracle日期类型操作几个问题>中,我们已经了 ...

  2. oracle 当前时间年月日时分秒,oracle存储精确时间 年月日 时分秒

    我用的是ibatis框架 为了做一个聊天功能,发现不能显示最新的消息,一看,原来oracle中存入的时间不对 oracle中要存入 年月日 时分秒首先要把 oracle中这列设置为 timestamp ...

  3. java获取指定格式的年月日时分秒时间

    /*** 通过Date类获取*/@Testpublic void getTimeNowThroughDate(){Date date=new Date();SimpleDateFormat simpl ...

  4. oracle sysdate取年月日,oracle获取当前年月日时分秒季度周

    oracle获取当前年月日时分秒季度周 2015-03-27 16:52阅读: 千万里的追寻 只愿静静抚慰那仅剩的0.1克自由灵魂 关注 oracle中如何获取系统当前时间 select to_cha ...

  5. oracle在数据表中获取年月日时分秒

    最近在用oracle数据库select数据,因为之前都是在用mysql,总是会遇到一些问题,记录一下. 如时间的取出问题,在数据库中格式是"年-月-日 时:分:秒"的格式,但是取出 ...

  6. oracle中获取年月日时分秒

    我写sql的时间为2016年10月10日下午15:18完事,这个时间下面要做对比: --获取年 select to_char(sysdate,'yyyy') from dual--2016 selec ...

  7. Oracle数据库将时间戳转换成年月日时分秒格式

    最近在工作中碰到了一个需求:需要将Oracle数据库中的时间戳转换成年月日时分秒的格式. 在查阅了相关文档.博客和资料后,实现了该需求,现在进行了总结,避免以后忘记. -- 需求:将时间戳: 1631 ...

  8. android 字符串 时间格式化,Android 获取年月日时分秒 格式化指定时间字符串

    1.获取Android系统当前时间年月日 时分秒(24小时制) //获取当前时间 Time time=new Time(); time.setToNow(); Log.i("cp" ...

  9. android 如何获得时间格式,Android 获取年月日时分秒 格式化指定时间字符串

    分享一下我老师大神的人工智能教程.零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow 1.获取Andro ...

最新文章

  1. Python 3.3.2中文版
  2. 《Enterprise Library深入解析与灵活应用》博文系列汇总
  3. Java NIO框架Netty教程(一) – Hello Netty
  4. Eclipse——WindowBuilder下载错误导致的安装失败解决方案
  5. Autofac之自动装配
  6. 使用C++的方式实现AES算法
  7. xshell 6 连接debian系统拒绝了密码_原来连接Linux,还有这个方法
  8. [转载] JAVA环境变量配置
  9. 如何看当前windows是utf8还是gbk_职场中的OKR如何“好好说话”
  10. c语言输入n打印数字菱形,打印数字菱形,急啊,帮帮小女子啊。。。
  11. 内存耗尽后,Redis会发生什么?
  12. 成都睿铂盘点无人机航测三个极端恶劣环境的人员与设备防护指南
  13. leetcode[35]搜索插入位置/Search Insert Position 暴力和二分法详解
  14. 2016.01.18 Xcode中的正则表达式
  15. TopJUI Combobox 联动
  16. u盘文件打不开怎么才能恢复
  17. 华为路由模拟器3.0参考实验8----单臂路由无法ping通问题分析
  18. 未安装AMD图形驱动程序,或者AMD驱动程序未正常工作。请安装与AMD硬件相对应的AMD驱动程序
  19. rtsp播放h265(hevc)
  20. “羊了个羊”是如何吸引住你的

热门文章

  1. 双汇大数据方案选型:从棘手的InfluxDB+Redis到毫秒级查询的TDengine
  2. python高斯核函数运用_高斯核函数
  3. html pc端移动端自适应,pc、移动端 自适应布局方案
  4. 软件成本估算之快速功能点方法应用示例
  5. C++——pair用法总结
  6. LockHunter 解锁猎人 v3.4.3.146 文件占用解除工具中文便携版
  7. 实现 图片由远及近的效果
  8. MacPorts 安装与使用
  9. USB描述符都是什么意思你看懂了吗?
  10. 计算机被限制无法打开C盘,Win7设置C盘提示“本次操作由于这台计算机限制而被取消”怎么办...