欢迎投稿

今日深度:

Oracle数据库中TRUNC()函数示例详解,

Oracle数据库中TRUNC()函数示例详解,


目录
  • 前言
  • 一、TRUNC函数的语法
  • 二、主要用途
  • 三、测试用例
    • 1、测试日期截取
    • 2、测试数值截取
  • 需要注意以下几点:
    • 总结

      前言

      在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()函数详解内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

      您可能感兴趣的文章:
      • oracle数据库删除数据Delete语句和Truncate语句的使用比较
      • Oracle round()函数与trunc()函数区别介绍
      • oracle trunc()函数的使用方法
      • 日常收集整理oracle trunc 函数处理日期格式(很实用)
      • oracle中函数 trunc(),round(),ceil(),floor的使用详解
      • Oracle常用函数Trunc及Trunc函数用法讲解
      • Oracle中trunc()函数实例详解

      www.htsjk.Com true http://www.htsjk.com/oracle/48620.html NewsArticle Oracle数据库中TRUNC()函数示例详解, 目录 前言 一、TRUNC函数的语法 二、主要用途 三、测试用例 1、测试日期截取 2、测试数值截取 需要注意以下几点: 总结 前言 在Oracle中,TRUNC函数用...
      评论暂时关闭