日期函数

目录

显示当前日期

显示当前的时间戳

计算若干天之后的日期

计算每一位员工到今天为止的雇佣天数

计算两个日期间所经历的月数总和

计算每一位员工到今天为止的雇佣总月数

计算每一位员工到今天为止所雇佣的年限

增加若干月之后的日期

测试 add_months() 函数

查询所有雇佣满 34 年的员工信息

计算指定日期所在月的最后一天

计算当前日期所在月的最后一天

查询所有在雇佣所在月倒数第二天被雇佣的员工信息

计算下一个指定的日期

计算下一个周二的日期


Oracle从入门到总裁:https://blog.csdn.net/weixin_67859959/article/details/135209645

显示当前日期

日期函数主要对日期进行处理,但是在整个日期处理过程中会存在一个关键的问题:如何取得当前的日期。为此在 Oracle 中专门提供一个数据伪列,这个列不存在于表中,但是却可以像表的列一样进行查询,这个伪列就是 sysdate

SQL> select ename, hiredate, sysdate2  from emp;ENAME                HIREDATE       SYSDATE
-------------------- -------------- --------------
SMITH                17-12月-80     02-2月 -24
ALLEN                20-2月 -81     02-2月 -24
WARD                 22-2月 -81     02-2月 -24
JONES                02-4月 -81     02-2月 -24
MARTIN               28-9月 -81     02-2月 -24
BLAKE                01-5月 -81     02-2月 -24
CLARK                09-6月 -81     02-2月 -24
KING                 17-11月-81     02-2月 -24
TURNER               08-9月 -81     02-2月 -24
JAMES                03-12月-81     02-2月 -24
FORD                 03-12月-81     02-2月 -24

尽管 emp 数据表中并没有字段 sysdate,但仍然可以看到 sysdate按照列的形式出现,显示当前日期

如果只想单独取得日期,可以简单一些,直接利用 dual 虚拟表即可

显示当前的时间戳

systimestamp显示当前的时间戳
Oracle 对于日期时间提供以下 3 种计算模式

日期 + 数字 = 日期(若干天之后的日期)

日期 - 数字 = 日期(若干天之前的日期)

日期 - 日期 = 数字(两个日期间的天数)

计算若干天之后的日期

SQL> select sysdate+10, sysdate+120, sysdate+99992  from dual;SYSDATE+10     SYSDATE+120    SYSDATE+9999
-------------- -------------- --------------
12-2月 -24     01-6月 -24     19-6月 -51

都是当前时间加多少天

在进行日期与数字的计算时,得到的结果都是比较容易理解的,因为结果仍然是一个日期。下面看 一下日期与日期之间相减是什么结果

计算每一位员工到今天为止的雇佣天数

SQL> select ename,hiredate,sysdate-hiredate2  from emp;ENAME                HIREDATE       SYSDATE-HIREDATE
-------------------- -------------- ----------------
SMITH                17-12月-80           15752.9303
ALLEN                20-2月 -81           15687.9303
WARD                 22-2月 -81           15685.9303
JONES                02-4月 -81           15646.9303
MARTIN               28-9月 -81           15467.9303
BLAKE                01-5月 -81           15617.9303
CLARK                09-6月 -81           15578.9303
KING                 17-11月-81           15417.9303
TURNER               08-9月 -81           15487.9303
JAMES                03-12月-81           15401.9303
FORD                 03-12月-81           15401.9303

通过以上结果发现,依靠天数实际上很难得到准确的年数或者月数,因为结果有若干位小数。例如 上面结果中“15752.9303”表示两者之间相差的天数还有小数点,由于存在闰年和闰月等影响的因素,很难确定这些天究竟是多少年或多少月

为了可以精确地进行计算,Oracle 提供了日期处理函数。利用这些函数可以避免闰年或闰月的问题

计算两个日期间所经历的月数总和

  months_between( 日期 1,日期 2)

计算每一位员工到今天为止的雇佣总月数

SQL> select ename, hiredate,months_between(sysdate,hiredate)2  from emp;ENAME                HIREDATE       MONTHS_BETWEEN(SYSDATE,HIREDATE)
-------------------- -------------- --------------------------------
SMITH                17-12月-80                           517.546258
ALLEN                20-2月 -81                           515.449484
WARD                 22-2月 -81                           515.384968
JONES                02-4月 -81                                  514
MARTIN               28-9月 -81                            508.19142
BLAKE                01-5月 -81                           513.062387
CLARK                09-6月 -81                           511.804323
KING                 17-11月-81                           506.546258
TURNER               08-9月 -81                           508.836581
JAMES                03-12月-81                           505.997871
FORD                 03-12月-81                           505.997871

有了月的数据,就可以准确计算年了。任何年份都只有 12 个月,这个是固定的

计算每一位员工到今天为止所雇佣的年限

SQL> select ename,hiredate,trunc(months_between(sysdate,hiredate)/12) years2  from emp;ENAME                HIREDATE            YEARS
-------------------- -------------- ----------
SMITH                17-12月-80             43
ALLEN                20-2月 -81             42
WARD                 22-2月 -81             42
JONES                02-4月 -81             42
MARTIN               28-9月 -81             42
BLAKE                01-5月 -81             42
CLARK                09-6月 -81             42
KING                 17-11月-81             42
TURNER               08-9月 -81             42
JAMES                03-12月-81             42
FORD                 03-12月-81             42

增加若干月之后的日期

  add_months( 日期,月数 )

函数运行结果返回对指定日期增加若干月之后的日期

测试 add_months() 函数

SQL> select add_months(sysdate,4),add_months(sysdate,24),add_months(sysdate,300)2  from dual;ADD_MONTHS(SYS ADD_MONTHS(SYS ADD_MONTHS(SYS
-------------- -------------- --------------
02-6月 -24     02-2月 -26     02-2月 -49

利用这种方式计算时间可以避免闰年、闰月的问题

查询所有雇佣满 34 年的员工信息

select * 
from emp
where trunc(months_between(sysdate,hiredate)/12)=34;

大家可以自己试下是什么结果

计算指定日期所在月的最后一天

  last_day( 日期 )

计算当前日期所在月的最后一天

SQL> select last_day(sysdate)2  from dual;LAST_DAY(SYSDA
--------------
29-2月 -24

查询所有在雇佣所在月倒数第二天被雇佣的员工信息

每个员工的雇佣日期是不一样的,所以每一个雇佣日期所在月的倒数第二天也不一样。首先应该知道每一位员工雇佣月的最后一天,而后利用 “日期 - 数字 = 日期” ,计算出倒数第二天

SQL> select ename,hiredate,last_day(hiredate),last_day(hiredate)-22  from emp3  where last_day(hiredate)-2=hiredate;ENAME                HIREDATE       LAST_DAY(HIRED LAST_DAY(HIRED
-------------------- -------------- -------------- --------------
MARTIN               28-9月 -81     30-9月 -81     28-9月 -81

计算下一个指定的日期

  next_day( 日期,一周时间数 )

计算下一个周二的日期

SQL> select next_day(sysdate,'星期二')2  from dual;NEXT_DAY(SYSDA
--------------
06-2月 -24

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/663808.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华为数通方向HCIP-DataCom H12-821题库(单选题:401-420)

第401题 R1的配置如图所示,此时在R1查看FIB表时,关于目的网段192.168.1.0/24的下跳是以下哪一项? A、10.0.23.3 B、10.0.12.2 C、10.0.23.2 D、10.0.12.1 【答案】A 【答案解析】 该题目考查的是路由的递归查询和 RIB 以及 FIB 的关系。在 RIB 中,静态路由写的是什么,下…

时间序列预测 —— TCN模型

时间序列预测 —— TCN模型 卷积神经网络(Convolutional Neural Network,CNN)在图像处理等领域取得了显著的成就,一般认为在处理时序数据上不如RNN模型,而TCN(Temporal Convolutional Network)…

十分钟上手vue!

Vue 是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,帮助你高效地开发用户界面。无论是简单还是复杂的界面,Vue 都可以胜任。 一 vue.js的导入及使用 vue安装…

微服务框架go-zero集成swagger在线接口文档

go-zero(收录于 CNCF 云原生技术全景图:CNCF Landscape)是一个集成了各种工程实践的 web 和 rpc 框架。通过弹性设计保障了大并发服务端的稳定性,经受了充分的实战检验。 go-zero 包含极简的 API 定义和生成工具 goctl,可以根据定义的 api 文件一键生成 Go, iOS, Android…

PostgreSQL从小白到高手教程 - 第44讲:pg流复制部署

PostgreSQL从小白到专家,是从入门逐渐能力提升的一个系列教程,内容包括对PG基础的认知、包括安装使用、包括角色权限、包括维护管理、、等内容,希望对热爱PG、学习PG的同学们有帮助,欢迎持续关注CUUG PG技术大讲堂。 第44讲&#…

AJAX-入门

定义 概念:AJAX是浏览器与服务器进行数据通信的技术 使用 1.先使用axios库,与服务器进行数据通信 1)基于XMLHttpRequest封装、代码简单、月下载量在14亿次 2)Vue、React项目中都会用到axios 2.再学习XMLHttpRequest对象的使用…

高宇辰:打造“π”型人才 | 提升之路系列(七)

导读 为了发挥清华大学多学科优势,搭建跨学科交叉融合平台,创新跨学科交叉培养模式,培养具有大数据思维和应用创新的“π”型人才,由清华大学研究生院、清华大学大数据研究中心及相关院系共同设计组织的“清华大学大数据能力提升项…

ElementUI Form:Upload 上传

ElementUI安装与使用指南 Upload 上传 点击下载learnelementuispringboot项目源码 效果图 el-upload.vue(Upload上传)页面效果图 el-upload.vue代码 import Vue from vue import VueRouter from vue-router import HomeView from ../views/HomeV…

【论文阅读笔记】Taming Transformers for High-Resolution Image Synthesis

Taming Transformers for High-Resolution Image Synthesis 记录前置知识AbstractIntroductionRelated WorkMethodLearning an Effective Codebook of Image Constituents for Use in TransformersLearning the Composition of Images with Transformers条件合成合成高分辨率图…

Interpolator:在Android中方便使用一些常见的CubicBezier贝塞尔曲线动画效果

说明 方便在Android中使用Interpolator一些常见的CubicBezier贝塞尔曲线动画效果。 示意图如下 import android.view.animation.Interpolator import androidx.core.view.animation.PathInterpolatorCompat/*** 参考* android https://yisibl.github.io/cubic-bezier* 实现常…

操作系统真象还原---系列笔记总结

闲话 最开始知道这本书是在校内论坛上,有同学通过这本书里的项目拿到大厂的ssp offer,于是就从网上订购了这本较为大部头的书,想要在简历上添加一个足够底层并且有意思的项目经历,从而帮助自己在秋招时赢得一个好的offer。 第一遍…

个人网站如何让搜索引擎收录

当我们花费功夫搭建好个人网站,如何能让搜索引擎搜索到个人网站呢?比如百度,根本百度不到自己网站的内容。这时候就要使用到搜索引擎提供的站点收录功能了,但是点开百度的搜索资源平台,添加自己的站点时,就…

Java/Python/Go不同开发语言基础数据结构和相关操作总结-Map篇

Java/Python/Go不同开发语言基础数据结构和相关操作总结 1. Java1.1 基础操作1.1.1 数据结构和定义方式1.1.2 增加1.1.3 修改1.1.4 查询1.1.5 删除1.1.6 获取总长度1.1.7 按key排序1.1.8 按value排序1.1.9 遍历 1.2 常用其他方法1.2.1 几种数据结构的对比 2. Go2.1基础操作2.1.…

C# 反射详解:动态编程的利器

文章目录 前言一、反射的原理二、反射的基本概念三、反射的主要API1、Type类:2、MemberInfo类:3、PropertyInfo类:4、MethodInfo类:5、Assembly类:6、EventInfo 类7、FieldInfo 类 四、使用场景五、使用方法1. 获取类型…

详解C++中auto关键字

auto关键字 auto关键字(C11)类型别名思考auto简介auto的使用细则auto与指针和引用结合起来使用在同一行定义多个变量 auto不能推导的场景1.auto不能作为函数的参数2.auto不能直接用来声明数组 auto关键字(C11) 类型别名思考 随着程序越来越复杂,程序中用到的类型也…

山东淄博刑侦大队利用无人机抓获盗窃团伙

山东淄博刑侦大队利用无人机抓获盗窃团伙 近期,山东淄博临淄区发生多起盗窃案件。通过视频追踪和调查访问,推断临淄区某村可能为嫌疑人藏匿地点。刑侦大队无人机应急小组迅速到达现场,经无人机高空侦查,发现并锁定了嫌疑人的藏匿…

vue使用pdf.js实现在线查看pdf文件

需求&#xff1a;有一个列表页&#xff0c;用户点击查看&#xff0c;弹层展示后台接口返回的pdf内容(不是文件、地址之类的&#xff0c;乱码的pdf铭文(二进制文件流)) 1、pdf.js安装 npm install --save vue-pdf2、正文代码 <template><div><el-table :data&q…

SpringBoot+Vue使用AES进行接口加密

目录 前言 一、前端工作准备 1.下载crypto-js 2.加密解密工具类 3.对axios请求拦截加密 二、后端工作准备 1.所需依赖 2.实现RequestBodyAdvice 3.实现HttpInputMessage 三、数据响应加密&#xff08;扩展&#xff09; 1.实现 ResponseBodyAdvice&#xff08;后端&#xff…

【python】RGB色彩空间转Lab色彩空间

用于检验的网站&#xff1a;颜色空间转换 - 在线工具 (buyaocha.com) 单个输入 import numpy as npdef rgb_to_xyz(rgb):# 将RGB值转换为XYZ空间rgb np.array(rgb) / 255.0rgb np.where(rgb < 0.04045, rgb / 12.92, ((rgb 0.055) / 1.055) ** 2.4)rgb rgb.reshape((…

格式化内存卡后,如何找回丢失的监控视频?

随着摄像头的应用越来越广泛&#xff0c;很多监控摄像头采用了内存卡作为存储介质&#xff0c;方便用户存储和查看摄像头拍摄的视频文件。然而&#xff0c;由于各种原因&#xff0c;监控摄像头的内存卡有时会被意外格式化导致重要数据的丢失&#xff0c;给用户带来诸多困扰。 那…