Oracle中trunc()函数实例详解

 更新时间:2023年01月13日 09:11:20   作者:睡竹  
trunc函数用法用于截取时间或者数值,返回指定的值,下面这篇文章主要给大家介绍了关于Oracle中trunc()函数详解的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

1、功能描述

用于截取时间或者数值,返回指定的值。

2、语法

2.1、数值处理:

格式:

trunc(number,[decimals])

  • number   : 为必要参数,是输入的一个数值
  • decimals :参数可忽略,是要截取的位数,缺省时表示截掉小数点后边的值。

案例1【第二个参数为正数时】:

select trunc(12345.6789,0)  from  dual  --返回结果为12345 --第二个参数省略,相当于0
select trunc(12345.6789,0)  from  dual  --返回结果为12345 --截取0位小数==去除小数
select trunc(12345.6789,1)  from  dual  --返回结果为12345.6    --截取一位小数
select trunc(12345.6789,2)  from  dual  --返回结果为12345.67
select trunc(12345.6789,5)  from  dual  --返回结果为12345.6789  

 案例2【第二个参数为负数时】:

select trunc(12345.6789,-1)  from  dual  --返回结果为12340,-1相当于整数位截取一位,这里的截取是把数值直接变为0,不会去截取位数,更不会四舍五入
select trunc(12345.6789,-2)  from  dual  --返回结果为12300
select trunc(12345.6789,-3)  from  dual  --返回结果为12000    
select trunc(12345.6789,-4)  from  dual  --返回结果为10000
select trunc(12345.6789,-5)  from  dual  --返回结果为0

2.2、日期处理:

格式:

trunc(date,[format])

  • date     :为必要参数,是输入的一个date日期值
  • format  :参数可忽略,是日期格式

format 常用取值:

  1. 缺省:                                  获取当前年月日:如:2022/7/21 
  2. y或yy或yyy或yyyy或year:  y 都是获取今天的一月一日:如:2022/1/1
  3. 'mm'或'month'                      当月的第一天:如:2022/7/1
  4. 'q':                                      本星期的第一天【是周日而不是周一】
  5. 'hh':                                    当前的小时:如:2022/7/21 17:00:00
  6. 'mi':                                    当前的时分:如:2022/7/21 17:48:00

案例1【缺省】

错误使用:

select trunc('2022/07/21')  from  dual  --报错,'2022/7/21'是一个字符串,不是date类型

正确方式:

--使用to_date函数,把字符串转为日期格式,注意:to_date的日期格式默认为yyyy/mm/dd
select trunc(to_date('2022/07/21','YYYY/MM/DD'))  from  dual  

结果:

2022/7/21

为了方便学习trunc函数,以下案例,都是用sysdate来代替日期数据【sysdate为当前时间】

如【我当前时间为2022/7/21】:

select sysdate  from  dual    --结果为当前时间:2022/7/21 17:18:18
 
select trunc(sysdate)  from  dual  --结果为2022/7/21

案例2【参数2位“y”】

select trunc(sysdate,'y')  from  dual  --结果为:2022/7/21 
select trunc(sysdate,'yy')  from  dual  --结果为:2022/7/21 
select trunc(sysdate,'yyy')  from  dual  --结果为:2022/7/21 
select trunc(sysdate,'yyyy')  from  dual  --结果为:2022/7/21 

案例3【参数2位“mm”】

select trunc(sysdate,'mm')  from  dual  --结果为:2022/7/1
select trunc(sysdate,'month')  from  dual  --结果为:2022/7/1

案例4【参数2位“q”】

select trunc(sysdate,'d')  from  dual  --结果为:2022/7/17 

案例5【参数2位“hh”】

select trunc(sysdate,'hh') from dual --结果为:2022/7/21 17:00:00

案例6【参数2位“mi”】

select trunc(sysdate,'mi')  from  dual  --结果为:2022/7/21 17:48:00

案例7

select trunc(sysdate) -1/24  from  dual  --结果为2022/7/20 23:00:00【当前日期为:2022/7/21】   -1/24表示24点的前1个小时
select trunc(sysdate) +2/24  from  dual  --结果为2022/7/21 2:00:00   +2/24表示24点的后2个小时

总结

到此这篇关于Oracle中trunc()函数详解的文章就介绍到这了,更多相关Oracle trunc()函数详解内容请搜索程序员之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持程序员之家!

相关文章

  • Oracle中的高效SQL编写PARALLEL解析

    Oracle中的高效SQL编写PARALLEL解析

    这篇文章主要介绍了Oracle中的高效SQL编写PARALLEL解析,在Oracle中,PARALLEL(并行)方式最大化调用计算机资源来成倍提高数据分析效率,这个在Oracle 9i之后的版本可以使用,需要的朋友可以参考下
    2023-07-07
  • Oracle触发器表发生了变化 触发器不能读它的解决方法(必看)

    Oracle触发器表发生了变化 触发器不能读它的解决方法(必看)

    下面小编就为大家带来一篇Oracle触发器表发生了变化 触发器不能读它的解决方法(必看)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • 如何Shrink Undo表空间,释放过度占用的空间

    如何Shrink Undo表空间,释放过度占用的空间

    如何Shrink Undo表空间,释放过度占用的空间...
    2007-03-03
  • plsql developer修改sql窗口的大小实现

    plsql developer修改sql窗口的大小实现

    本文主要介绍了plsql developer修改sql窗口的大小实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-08-08
  • Oracle递归查询简单示例

    Oracle递归查询简单示例

    最近在做一个树状编码管理系统,其中用到了oracle的树状递归查询,下面这篇文章主要给大家介绍了关于Oracle递归查询的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • Oracle SQL中实现indexOf和lastIndexOf功能的思路及代码

    Oracle SQL中实现indexOf和lastIndexOf功能的思路及代码

    INSTR的第三个参数为1时,实现的是indexOf功能;为-1时实现的是lastIndexOf功能,具体实现如下,感兴趣的朋友可以参考下哈下,希望对大家有所帮助
    2013-05-05
  • oracle排名函数的使用方法分享

    oracle排名函数的使用方法分享

    本文介绍下,oracle中排名函数的用法,通过实例学习oracle排名函数的具体用法,有需要的朋友可以参考下
    2014-06-06
  • Oracle数据库技术(38)

    Oracle数据库技术(38)

    Oracle数据库技术(38)...
    2007-03-03
  • Oracle表空间设置和管理浅析

    Oracle表空间设置和管理浅析

    这篇文章主要给大家介绍了关于Oracle表空间设置和管理的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Oracle具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • oracle数据库定时任务dbms_job的用法详解

    oracle数据库定时任务dbms_job的用法详解

    这篇文章给大家详细介绍了dbms_job的用法,用于安排和管理作业队列,通过使用作业,可以使ORACLE数据库定期执行特定的任务。有需要的朋友们可以参考借鉴。
    2016-09-09

最新评论

?


http://www.vxiaotou.com