当前位置: 首页 > news >正文

Oracle中TRUNC()函数详解

文章目录

  • 前言
  • 一、TRUNC函数的语法
  • 二、主要用途
  • 三、测试用例
  • 总结


前言

在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函数用于截断日期或数值的小数部分。它具有以下用途:

  1. 截断日期部分:当TRUNC函数应用于日期时,它会截断日期的时间部分,返回一个新的日期,时间部分设置为零。例如,TRUNC(SYSDATE)将返回当前日期,时间部分设置为零。

  2. 截断时间部分:当TRUNC函数应用于时间时,它将返回一个新的时间,将分钟、秒和毫秒部分设置为零。例如,TRUNC(SYSTIMESTAMP)将返回当前时间,分钟、秒和毫秒部分设置为零。此外,还可以指定截取的位数,例如TRUNC(date, ‘MONTH’)可以截取日期的月份部分。还可以用于将日期或时间戳向下取整到指定的单位,比如TRUNC(date, ‘IW’)可以将日期向下取整到本周的第一天。

  3. 截断数值部分:当TRUNC函数应用于数值时,它将截断数值的小数部分,并返回一个新的数值。例如,TRUNC(3.14159)将返回3。

  4. 截断小数部分:当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;

测试结果:
在这里插入图片描述


总结

总的来说,TRUNC函数可以用于截断日期的时间部分、时间的分钟、秒和毫秒部分、数值的小数部分,并可以指定截断的精度。

如果这篇博客对大家有所帮助,我希望能得到各位的免费点赞收藏,作为对我的鼓励和支持。
同时,也请大家在评论区留下您宝贵的意见和建议,我将非常欢迎。
感谢大家的支持评论收藏!!!

http://www.lryc.cn/news/451856.html

相关文章:

  • 【Spring Boot 入门一】构建你的第一个Spring Boot应用
  • PPT 快捷键使用、技巧
  • Web安全 - 文件上传漏洞(File Upload Vulnerability)
  • vue3中el-input在form表单按下回车刷新页面
  • SQL Server中关于个性化需求批量删除表的做法
  • 关于按键状态机解决Delay给程序带来的问题
  • 62.【C语言】浮点数的存储
  • GO网络编程(一):基础知识
  • 【Linux】用虚拟机配置Ubuntu环境
  • 酒店智能门锁SDK接口pro[V10] 门锁校验C#-SAAS本地化-未来之窗行业应用跨平台架构
  • Gitのrebase用法
  • 二分查找一>:在排序数组中查找元素的第一个和最后一个位置
  • undeclared identifier ‘UNITY_PREV_MATRIX_M‘ - Unity Shader自己写URP,引用内部 hlsl
  • 信息安全工程师(29)存储介质安全分析与防护
  • Html5知识点介绍
  • 探索机器学习中的特征选择技术
  • 数造科技入选中国信通院《高质量数字化转型产品及服务全景图》三大板块
  • 什么是分布式数据库
  • 从u盘直接删除的文件能找回吗 U盘文件误删除如何恢复
  • 如何使用ssm实现基于HTML的中国传统面食介绍网站的搭建+vue
  • 【生成模型】学习笔记
  • 大语言模型知识点分享
  • openpnp - 底部相机高级校正的参数设置
  • 劳动与科技、艺术结合更好提高劳动教育意义
  • 基于Hive和Hadoop的招聘分析系统
  • 目标检测评价指标
  • 解决VRM格式模型在Unity中运行出现头发乱飞等问题
  • 消息中间件---初识(Kafka、RocketMQ、RabbitMQ、ActiveMQ、Redis)
  • MySQL高阶2010-职员招聘人数2
  • 【Java】—— 集合框架:Collection接口中的方法与迭代器(Iterator)