百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

mysql和Oracle 查询某个时间之内的数据

csdh11 2024-12-08 12:59 22 浏览

查询最近一个月的数据

MySql

SELECT id,title,endtime from classroom where years = 2022 and date_sub(CURDATE(), interval 1 month) < endtime ;

DATE_SUB() 函数从日期减去指定的时间间隔,本文是从当前时间减去一个月。

CURDATE() 函数表示当前年月日,NOW()函数表示当前年月日时分秒,CURTIME()函数表示时分秒。

Oracle

查询最近一个月的数据

SELECT * FROM 表名
WHERE 日期列 between to_char(sysdate-30,'yyyy-mm-dd hh24:mi:ss') and to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')
SELECT * FROM 表名
WHERE to_char(日期列,'yyyy-mm-dd hh24:mi:ss') between to_char(sysdate-30,'yyyy-mm-dd hh24:mi:ss') and to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')

获得一个小时前,一天内、一个星期前、一个月前、一年前的日期

获取10分钟前的日期
select sysdate,sysdate-interval '10' minute from dual;  
获取一个小时前的日期
方式1:select sysdate,sysdate-interval '1' hour from dual;

方式2:select sysdate,sysdate-1/24 from dual;  
获取一天前的日期
select sysdate, sysdate - interval '1' day from dual;
select sysdate, sysdate - 1 from dual;
获取一周前的日期
select sysdate, sysdate - interval '7' day from dual;
 

获取一个月前的日期
select sysdate,sysdate-interval '1' month from dual;
 

获取一年前的日期
select sysdate,sysdate-interval '1' year from dual;
 

获取某一个月的总天数
select to_number(to_char(last_day(to_date('2018-09','yyyy-mm')),'dd')) from dual;
 

查询某一个月的全部日期
SELECT TO_CHAR(TRUNC(to_date('2018-09','yyyy-MM'), 'MM') + ROWNUM - 1,'yyyy-MM-dd') someday  FROM DUAL
 CONNECT BY ROWNUM <= TO_NUMBER(TO_CHAR(LAST_DAY(to_date('2018-09','yyyy-MM')), 'dd'));

10分钟内,一个小时内,一天内、一个星期内、一个月内、一年内的数据

获取10分钟内的数据
SELECT count(*) FROM TB WHERE 字段 BETWEEN sysdate-interval '10' minute AND SYSDATE;
 

获取一个小时内的数据
SELECT count(*) FROM TB WHERE 字段 BETWEEN sysdate-interval '1' hour AND SYSDATE;

SELECT count(*) FROM TB WHERE 字段 BETWEEN sysdate-1/24 AND SYSDATE;
 

获取一天内的数据
SELECT count(*) FROM TB WHERE 字段 BETWEEN SYSDATE-1 AND SYSDATE;
 

获取一周内的数据
select count(*) from TB where 字段 > sysdate - interval '7' day;

select count(*) from TB where 字段 > sysdate - 7;
 

获取一个月内的数据
select count(*) from TB where 字段 > add_months(sysdate,-1);

SELECT count(*) FROM TB WHERE 字段 BETWEEN sysdate-interval '1' month AND SYSDATE;
 

获取一年内的数据

select count(*) from TB WHERE 字段 BETWEEN sysdate-interval '1' year AND SYSDATE;
三、其他
select sysdate -1 from dual
----结果减一天,也就24小时
select sysdate-(1/2) from dual
-----结果减去半天,也就12小时
select sysdate-(1/24) from dual
-----结果减去1 小时
select sysdate-((1/24)/12) from dual
----结果减去5分钟
select sysdate-(level-1) from dual connect by level<=10
---结果是10间隔1天的时间

查询确定年月的数据,使用to_date或to_char,以2021年4月为例

SELECT * FROM 表名
WHERE TO_CHAR(日期列,'YYYY-MM') = TO_CHAR('2021-04','YYYY-MM')   或者
 
SELECT * FROM 表名
WHERE 日期列 = TO_Date('2021-04','YYYY-MM')


  -- 查询近30天的数据,此处  时间字段  为 VarChar 类型,
SELECT 
	需要返回的字段
FROM 库表名称
WHERE TRUNC(TO_DATE(SUBSTR(时间字段, 1, 10),'yyyy-mm-dd')) >= TRUNC(SYSDATE-30);
 
-- 查询近30天的数据,此处  时间字段 为 日期 类型,
SELECT 
	需要返回的字段
FROM 库表名称
WHERE TRUNC(时间字段) >= TRUNC(SYSDATE-30);


select
    'last_30days' as time_range,
    sum(exit_time)/count(exit_time) as avg_clr_time
from
    clr.dws_dcon_average_cce_m
    WHERE TRUNC(D_RG_TIME) >= TRUNC(SYSDATE-30);--从本地时间往前三十天
 
--TRUNC(D_RG_TIME) >= TRUNC(SYSDATE-3);--从本地时间往前三天
--TRUNC(D_RG_TIME) >= TRUNC(SYSDATE-365);--从本地时间往前365天

相关推荐

IDEA界面太丑??尝试一下这几个插件

前言IntelliJIDEA主要用于支持Java、Scala、Groovy等语言的开发工具,同时具备支持目前主流的技术和框架,擅长于企业应用、移动应用和Web应用的开发。IntelliJi...

小巧 Vue 页面滚动进度条组件ScrollProgress

今天给大家分享一个轻量级Vue.js全屏滚动进度条组件VueScrollProgress。vue-scroll-progress一款基于vue.js构建的页面滚动进度条组件,...

基于vue实现可视化拖拽编辑器,页面生成工具,提升前端开发效率

项目介绍基于vue实现的可视化拖拽编辑器,实现页面生成工具,提升前端开发效率。可以基层到移动端项目作为自定义json直接生成UI页面。项目特点功能特点...

优秀 vue+heyui 后端管理系统HeyUI-Admin

今天再给小伙伴们推荐一款成熟的企业中后台管理系统HEYUI-Admin。heyui-admin基于vue.js和heyui组件库构建的后台管理系统。包含基础表单/表格功能,拓展组件(图表、富文本编辑...

响应式 Vue.js 前端组件化框架Xvue-UI

今天给小伙伴们推荐一款超不错的Vue轻量级组件框架XVueUI。xvue-ui基于vue2.x构建的响应式前端组件化框架。轻量级、易于上手,提供...

《基于SpringBoot+Vue的在线视频系统设计与实现》开题报告

【计算机毕业设计案例】基于SpringBoot+Vue的在线视频系统设计与实现_哔哩哔哩_bilibili...

超好用 Vue.js 图片裁切组件Vue-ImgCutter

今天给小伙伴们分享一个超棒的Vue图片任意裁剪插件VueImgCutter。vue-img-cutter基于vue2.x构建的轻量级剪切图片组件。支持移动图像、放大缩小图片、任意移动图片、固定比...

Vue 3 进阶用法:异步组件(vue 异步组件原理)

一、代码分割一个大型前端应用,如果所有代码都放在单一文件,体积会特别大,下载时间长,白屏时间久,用户体验差。...

源码补丁神器—patch-package(源码助手怎么用)

作者:张浩一、背景vue项目中使用vue-pdf第三方插件预览pdf,书写业务代码完美运行,pdf文件内容正常预览无问题。后期需求有变,业务需求增加电子签章功能。这个时候pdf文件的内容可以显示出...

经验分享:Vue2 项目升级 Vue3 + Element Plus,借助Deepseek手动升级

Vue3出来好久了,我开发的项目还在使用Vue2框架,一般情况下不考虑升级,但是最近需要接入工作流程引擎之类的,看了下Vue2生态下操作空间不是很好,那索性尝试升级Vue3吧。一番操作下来,升级成功,...

34K Star!史上最全JavaScript资源库 awesome-javascript

34KStar!史上最全JavaScript资源宝库大揭秘引言在GitHub上,有一个备受瞩目的JavaScript资源仓库,以其全面的内容和精心的分类,成为了众多开发者的必备参考。这个拥有超过...

基于 Vue.js 磁片栅格布局组件VueGridLayout

#头条创作挑战赛#今天给大家分享一个超优秀的vue.js拖拽栅格布局插件VueGridLayout。...

6款高颜值 Vue3 PC端UI组件库(vue3开发组件库)

马上到国庆了,还没学习或者想学习vue3的小伙伴们有安排上没?这次推荐几个比较流行的VUE3UI组件库,合理利用,又或者学习借鉴都是不错的选择。1、element-pluselement-plus...

高性能 vue.js+ztree 树形组件Vue-GiantTree

今天给大家分享一款超棒的Vue海量数据渲染树形组件VueGiantTree。vue-giant-tree基于ztree封装的Vue树形组件。轻松实现大数据高性能渲染,适合海量数据渲染场景。zTr...

【推荐】2024年推荐的6款开源免费 Vue 后台管理系统模板,建议收藏

前言在现今的软件开发领域,...