前言
在oracle中,trunc函数用于截取或截断日期、时间或数值表达式的部分。它返回一个日期、时间或数值的截断版本,根据提供的格式进行截取。
一、trunc函数的语法
trunc(date) trunc(date, [format]) trunc(number) trunc(number, precision)
参数说明:
- date: 一个日期或时间表达式。
- format: 可选参数,用于指定截取的精度。可以是以下值之一:
参数 | 说明 |
---|---|
yyyy | 年份 |
yyyy-mm | 年份和月份 |
yyyy-mm-dd | 年份、月份和日期 |
yyyy-mm-dd hh24 | 年份、月份、日期和小时(24小时制) |
yyyy-mm-dd hh24:mi | 年份、月份、日期、小时和分钟 |
yyyy-mm-dd hh24:mi:ss | 年份、月份、日期、小时、分钟和秒钟 |
yyyy-mm-dd hh24:mi:ss.ff | 年份、月份、日期、小时、分钟、秒钟和毫秒 |
- number: 一个数值表达式,可以是整数或浮点数。
- precision: 可选参数,用于指定数值的截取精度。表示保留到小数点后多少位,默认为0。
二、主要用途
在oracle中,trunc函数用于截断日期或数值的小数部分。它具有以下用途:
截断日期部分:当trunc函数应用于日期时,它会截断日期的时间部分,返回一个新的日期,时间部分设置为零。例如,trunc(sysdate)将返回当前日期,时间部分设置为零。
截断时间部分:当trunc函数应用于时间时,它将返回一个新的时间,将分钟、秒和毫秒部分设置为零。例如,trunc(systimestamp)将返回当前时间,分钟、秒和毫秒部分设置为零。此外,还可以指定截取的位数,例如trunc(date, ‘month’)可以截取日期的月份部分。还可以用于将日期或时间戳向下取整到指定的单位,比如trunc(date, ‘iw’)可以将日期向下取整到本周的第一天。
截断数值部分:当trunc函数应用于数值时,它将截断数值的小数部分,并返回一个新的数值。例如,trunc(3.14159)将返回3。
截断小数部分:当trunc函数应用于数值时,可以指定截断的精度。例如,trunc(3.14159, 2)将返回3.14,截断到小数点后两位。
注意,trunc函数并不四舍五入,而是直接截取。如果需要进行四舍五入操作,可以使用sql中的round函数。
三、测试用例
1、测试日期截取
测试sql:
select trunc(sysdate,'yyyy') as year_trunc, trunc(sysdate,'mm') as month_trunc, trunc(sysdate,'dd') as day_trunc, trunc(sysdate,'hh24') as hour_trunc, trunc(sysdate,'mi') as minute_trunc, trunc(sysdate) -1/24 as first_trunc, trunc(sysdate) +2/24 as second_trunc from dual;
测试结果:
其中:最后2个用例,分别表示-1/24表示24点的前1个小时;+2/24表示24点的后2个小时。
2、测试数值截取
测试sql:
select trunc(12345.6789) as number1, trunc(12345.6789,0) as number2, trunc(12345.6789,1) as number3, trunc(12345.6789,2) as number4, trunc(12345.6789,3) as number5, trunc(12345.6789,4) as number6, trunc(12345.6789,-1) as number7, trunc(12345.6789,-2) as number8, trunc(12345.6789,-3) as number8, trunc(12345.6789,-4) as number10 from dual;
测试结果:
需要注意以下几点:
- 对于日期参数,format参数是可选的。如果省略了format参数,默认情况下会截断到天。
- 对于数值参数,decimal_places参数用于指定要保留的小数位数。它可以为正数(截断)或负数(进位)。
- trunc()函数可以与其他函数和表达式结合使用,以便进行更复杂的数据操作和计算。
总结
总的来说,trunc函数可以用于截断日期的时间部分、时间的分钟、秒和毫秒部分、数值的小数部分,并可以指定截断的精度。
到此这篇关于oracle数据库中trunc()函数的文章就介绍到这了,更多相关oracle trunc()函数详解内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论