文章摘要
这篇文章介绍了Oracle中`trunc()`函数的使用方法及其核心功能。`trunc()`函数用于截取数值或日期的一部分,返回指定的值。其语法分为两部分:数值截取和日期处理。 **功能描述**: `trunc()`函数用于截取数值或日期的部分。数值截取时,第二个参数表示截取的位数,默认截掉小数部分;日期处理时,第二个参数是一个格式字符串,用于指定截取的日期部分。 **语法**: 1. 数值截取: `trunc(number, [decimals])` - `number`:必要参数,输入的数值 - `decimals`:可忽略,默认截掉小数部分,也可指定截取的位数 2. 日期处理: `trunc(date, [format])` - `date`:必要参数,输入的日期值 - `format`:可忽略,默认获取当前年月日,也可指定其他日期格式(如月、年、星期等) **案例解析**: - 数值截取: - `trunc(12345.6789, 0)` 截取整数部分(12345) - `trunc(12345.6789, 1)` 截取一位小数(12345.6) - `trunc(12345.6789, -1)` 截取整数位(12340) - 日期处理: - 使用`to_date()`函数将字符串转换为date类型,例如: `trunc(to_date('2022/07/21', 'YYYY/MM/DD'))` - 格式字符串可指定截取日期的详细程度,例如: - `trunc(sysdate, 'y')` 截取年份 - `trunc(sysdate, 'mm')` 截取月份 - `trunc(sysdate, 'mi')` 截取时分 总结:`trunc()`函数在数值截取和日期处理中表现灵活,支持多种截取方式,适用于数据处理和分析。
目录1、功能描述2、语法2.1、数值处理:2.2、日期处理:总结
用于截取时间或者数值,返回指定的值。
格式:
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
格式:
trunc(date,[format])
date :为必要参数,是输入的一个date日期值format :参数可忽略,是日期格式
format 常用取值:
缺省: 获取当前年月日:如:2022/7/21 y或yy或yyy或yyyy或year: y 都是获取今天的一月一日:如:2022/1/1’mm’或’month’ 当月的第一天:如:2022/7/1’q’: 本星期的第一天【是周日而不是周一】’hh’: 当前的小时:如:2022/7/21 17:00:00’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 round()函数与trunc()函数区别介绍oracle中函数 trunc(),round(),ceil(),floor的使用详解Oracle常用函数Trunc及Trunc函数用法讲解日常收集整理oracle trunc 函数处理日期格式(很实用)oracle trunc()函数的使用方法Oracle自我补充之trunc()函数的使用方法