您的位置:首页技术文章

Oracle中trunc()函数实例详解

浏览:98日期:2023-03-08 16:57:25
目录
  • 1、功能描述
  • 2、语法
    • 2.1、数值处理:
    • 2.2、日期处理:
  • 总结

    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