oracle-函数-trunc-round-日期函数

2024-04-12 16:48
文章标签 oracle 函数 round 日期 trunc

本文主要是介绍oracle-函数-trunc-round-日期函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、oracle trunc函数处理日期

select trunc(sysdate) from dual; --默认截取到天

2017-09-12 00:00:00

select trunc(sysdate,'dd') from dual;--截取到天

2017-09-12 00:00:00

select trunc(sysdate,'') from dual; 

select trunc(sysdate,'year') from dual; --截取到年(本年的第一天)

select trunc(sysdate,'q') from dual; --截取到季度(本季度的第一天)

select trunc(sysdate,'month') from dual; --截取到月(本月的第一天)

 

select trunc(sysdate,'w') from dual;  -- 离当前时间最近的周四,若当天为周四则返回当天,否则返回上周四????

select trunc(sysdate,'ww') from dual;  --截取到上周末(上周周六)????

 

 

select trunc(sysdate,'day') from dual; --截取到周(本周第一天,即上周日)

select trunc(sysdate,'iw') from dual; --本周第2天,即本周一

 

 

select trunc(sysdate,'hh24') from dual;  --截取到小时(当前小时,零分零秒)

2011-12-29 16:00:00

select trunc(sysdate,'mi') from dual; --截取到分(当前分,零秒)

2011-12-29 16:24:00

 

select trunc(sysdate,'ss') from dual ;--报错,没有精确到秒的格式

 

 

二、oracle trunc函数处理数值

trunc(x[,y]) 
【功能】返回x按精度y截取后的值 
【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则截取到y位小数,如果y小于0则截取到小数点向左第y位,小数前其它数据用0表示。 如果y小于0,且y的绝对值大于或等于x整数的位数,则返回为0。如:TRUNC(89.985,-3)=0。
【返回】数字 
【示例】 

selecttrunc(5555.66666,2.7),trunc(5555.66666,-2.6),trunc(5555.733333) fromdual;  

返回:5555.66  5500  5555

selectTRUNC(89.985,-3) fromdual; --0

select TRUNC(89.985,-2) from dual; --0

 

三、oracle round函数处理数值

round(x[,y]) 
【功能】返回四舍五入后的值 
【参数】x,y,数字型表达式;y的默认值为0;如果y不为整数则截取y整数部分,如果y>0则四舍五入为y位小数,如果y小于0则四舍五入到小数点向左第y位。 
【返回】数字 
【示例】 select round(1.6),round(1.6,0),round(5555.6666,2.1),round(5555.6666,-2.6),round(5555.6666) from dual; 

返回: 2 , 2 , 5555.67 , 5600 , 5556 
【相近】trunc(x[,y]) 返回截取后的值,用法同round(x[,y]),只是不四舍五入

 

四、oracle round函数处理日期

ROUND(d[,fmt])

ROUND(d[,fmt])

ROUND(d[,fmt])

【功能】返回一个以fmt为格式的四舍五入日期值 
【参数】d是日期,fmt是格式 模型。默认fmt为DDD,即月中的某一天。 

      如果fmt为“YEAR”则舍入到某年的1月1日,即前半年舍去,后半年作为下 一年

      如果fmt为“MONTH”则舍入到某月的1日,即前月舍去,后半月作为下一 月

      默认为“DDD”,即月中的某一天,最靠近的天,前半天舍去,后半天作为第二天

      如果fmt为“DAY”则舍入到最近的周的周日,即上半周舍去,下半周作为下 一周周日

【返回】日期 
【示例】 select sysdate,round(sysdate),round(sysdate,'ddd'),

        round(sysdate,'day'),round(sysdate,'month'),round(sysdate,'year') from dual; 

    返回: 2017-09-13 16:11:13 , 2017-09-14 00:00:00 , 2017-09-14 00:00:00 , 

       2017-09-17 00:00:00 , 2017-09-01 00:00:00 , 2018-01-01 00:00:00

 

 

、oracle 日期函数:ADD_MONTHS、LAST_DAY、EXTRACT

1. ADD_MONTHS(d,n),在某一个日期d上,加上指定的月数n,返回计算后的新日期
【示例】 select sysdate,add_months(sysdate,5) fromdual;

    返回: 2017-09-13 16:35:19 , 2018-02-13 16:35:19

 

2. LAST_DAY(d),返回指定日期当月的最后一天
【示例】 select sysdate,LAST_DAY(sysdate) fromdual;

    返回: 2017-09-13 16:35:19 , 2017-09-30 16:35:19 

 

4. EXTRACT(fmt FROM d),提取日期中的特定部分。

【参数】fmt为:YEAR、MONTH、DAY、HOUR、MINUTE、SECOND。

        其中YEAR、MONTH、DAY可以为DATE类型匹配,也可以与TIMESTAMP类型匹配;

        但是HOUR、MINUTE、SECOND必须与TIMESTAMP类型匹配。

        HOUR匹配的结果中没有加上时区,因此在中国运行的结果小8小时。

【返回】数字 
【示例】 

select sysdate,systimestamp,

  extract(yearfrom sysdate),extract(monthfrom sysdate),extract(dayfrom sysdate),

  extract(hour from systimestamp),extract(minute from systimestamp),extract(second from systimestamp) 

 

fromdual;

    返回: 2017-09-13 16:52:58 , 2017-09-13 17:05:25  GMT+08:00 ,

       2017 , 9 , 13 , 8 , 52 , 58.75

       

这篇关于oracle-函数-trunc-round-日期函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897698

相关文章

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

Oracle登录时忘记用户名或密码该如何解决

《Oracle登录时忘记用户名或密码该如何解决》:本文主要介绍如何在Oracle12c中忘记用户名和密码时找回或重置用户账户信息,文中通过代码介绍的非常详细,对同样遇到这个问题的同学具有一定的参... 目录一、忘记账户:二、忘记密码:三、详细情况情况 1:1.1. 登录到数据库1.2. 查看当前用户信息1.

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

golang panic 函数用法示例详解

《golangpanic函数用法示例详解》在Go语言中,panic用于触发不可恢复的错误,终止函数执行并逐层向上触发defer,最终若未被recover捕获,程序会崩溃,recover用于在def... 目录1. panic 的作用2. 基本用法3. recover 的使用规则4. 错误处理建议5. 常见错

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

PLsql Oracle 下载安装图文过程详解

《PLsqlOracle下载安装图文过程详解》PL/SQLDeveloper是一款用于开发Oracle数据库的集成开发环境,可以通过官网下载安装配置,并通过配置tnsnames.ora文件及环境变... 目录一、PL/SQL Developer 简介二、PL/SQL Developer 安装及配置详解1.下

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

springboot日期格式化全局LocalDateTime详解

《springboot日期格式化全局LocalDateTime详解》文章主要分析了SpringBoot中ObjectMapper对象的序列化和反序列化过程,并具体探讨了日期格式化问题,通过分析Spri... 目录分析ObjectMapper与jsonSerializer结论自定义日期格式(全局)扩展利用配置