• Oracle根据时间查询


    1. 查询时间段之内的数据

    查询2021-01-01  至  2021-01- 02 的数据
    SELECT *
    FROM t_table1 t
    WHERE t.d_time >= to_date('2021-01-01 00:00:00', 'yyyy-mm-dd hh24:mi:ss')
    	AND t.d_time <= to_date('2021-01-02 23:59:59', 'yyyy-mm-dd hh24:mi:ss');
    
    • 1
    • 2
    • 3
    • 4
    • 5

    以下SQL,只会查询2021-01-01至2021-1-2 00:00:00的数据

    SELECT *
    FROM T_EVENT_MANAGEMENT t
    WHERE t.s_ra_time >= to_date('2021-01-01', 'yyyy-mm-dd')
    	AND t.s_ra_time <= to_date('2021-01-02', 'yyyy-mm-dd');
    --to_date('2021-01-02', 'yyyy-mm-dd') = 2021-01-02 00:00:00 超过2号0点属于2号的数据不会显示
    
    • 1
    • 2
    • 3
    • 4
    • 5

    2. 日期和字符转换函数用法(to_date,to_char)

    select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual;  --结果:2022-01-26 13:04:53
    select to_char(sysdate,'yyyy') as nowYear   from dual; --结果:2022
    select to_char(sysdate,'mm')   as nowMonth  from dual; --结果:01
    select to_char(sysdate,'dd')   as nowDay    from dual; --结果:26
    select to_char(sysdate,'hh24') as nowHour   from dual; --结果:13
    select to_char(sysdate,'mi')   as nowMinute from dual; --结果:04
    select to_char(sysdate,'ss')   as nowSecond from dual; --结果:53
    
    
    select to_date('2022-01-26 13:04:53','yyyy-mm-dd hh24:mi:ss')  from dual
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    3. 查询某天星期几

    select to_char(to_date('2022-01-26','yyyy-mm-dd'),'day') from dual;   --结果:星期三
    
    • 1

    4. 两个日期直接相差天数

     select floor(sysdate - to_date('20220101','yyyymmdd')) from dual;  
    
    • 1

    5. 查询出一个空的时间类型

    select 1, TO_DATE(null) from dual;
    
    • 1

    在这里插入图片描述

    6. 用于计算date1和date2之间有几个月

    select months_between(to_date('12-31-2021','MM-DD-YYYY'),to_date('01-31-2021','MM-DD-YYYY')) "MONTHS" FROM DUAL;  --结果:11
    
    • 1

    7. 指定时间的下一个星期几(由char指定)所在的日期,

    NEXT_DAY(date,char) 
    
    select   next_day(sysdate,2) from dual;  --当前时间的下一个周一
    --1表示星期日,2代表星期一
    
    • 1
    • 2
    • 3
    • 4

    8. 获取今年的天数

    select add_months(trunc(sysdate,'year'), 12) - trunc(sysdate,'year') from dual;
     --闰年的处理方法     
    to_char( last_day( to_date('02'|| :year,'mmyyyy') ), 'dd')     
     --如果是28就不是闰年
    
    • 1
    • 2
    • 3
    • 4

    9. 获取当前时间是今年的第多少天

     select TO_CHAR(SYSDATE,'DDD'),sysdate from dual;
    
    • 1

    trunc[截断到最接近的日期,单位为天] ,返回的是日期类型

     select sysdate S1,                    
         trunc(sysdate) S2,                 //返回当前日期,无时分秒
         trunc(sysdate,'year') YEAR,        //返回当前年的1月1日,无时分秒
         trunc(sysdate,'month') MONTH ,     //返回当前月的1日,无时分秒
         trunc(sysdate,'day') DAY           //返回当前星期的星期天,无时分秒
       from dual
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    10. 返回日期列表中最晚日期

    select greatest('2021-01-04','2022-01-04','2019-02-04') from dual;  --结果:2022-01-04
    
    • 1

    11. 计算时间差

     select floor(to_number(sysdate-to_date('2020-11-02 15:55:03','yyyy-mm-dd hh24:mi:ss'))/365) as spanYears from dual        //时间差-年
    select ceil(months_between(sysdate,to_date('2020-11-02 15:55:03','yyyy-mm-dd hh24:mi:ss'))) as spanMonths from dual        //时间差-月
    select floor(to_number(sysdate-to_date('2020-11-02 15:55:03','yyyy-mm-dd hh24:mi:ss'))) as spanDays from dual             //时间差-天
    select floor(to_number(sysdate-to_date('2020-11-02 15:55:03','yyyy-mm-dd hh24:mi:ss'))*24) as spanHours from dual         //时间差-时
    select floor(to_number(sysdate-to_date('2020-11-02 15:55:03','yyyy-mm-dd hh24:mi:ss'))*24*60) as spanMinutes from dual    //时间差-分
    select floor(to_number(sysdate-to_date('2020-11-02 15:55:03','yyyy-mm-dd hh24:mi:ss'))*24*60*60) as spanSeconds from dual //时间差-秒
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    12. 查找月的第一天,最后一天

     SELECT Trunc(Trunc(SYSDATE, 'MONTH') - 1, 'MONTH') First_Day_Last_Month,  --最后一月最后一天
           Trunc(SYSDATE, 'MONTH') - 1 / 86400 Last_Day_Last_Month,            --最后一月最后一天
           Trunc(SYSDATE, 'MONTH') First_Day_Cur_Month,                        --当前月第一天
           LAST_DAY(Trunc(SYSDATE, 'MONTH')) + 1 - 1 / 86400 Last_Day_Cur_Month --当前月最后一天
       FROM dual;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    13. 查询时间之前的时间(查之后把减号换成加号)

    当前时间减去7分钟的时间
    select sysdate,sysdate - interval '7' MINUTE from dual
    
    当前时间减去7小时的时间
    select sysdate - interval '7' hour from dual
    
    当前时间减去7天的时间
    select sysdate - interval '7' day from dual
    
    当前时间减去7月的时间
    select sysdate,sysdate - interval '7' month from dual
    
    当前时间减去7年的时间
    select sysdate,sysdate - interval '7' year from dual
    
    时间间隔乘以一个数字(也就是8个小时*2倍,16个小时之前的数据)
    select sysdate,sysdate - 8 *interval '2' hour from dual
    
     
    获取七天之后的时间
    select (sysdate + 7) from dual;
    
    获取前一个月的时间(正数时是加月,负数时为减月)
    select add_months(sysdate,-1) from dual;
    
    select sysdate+1 from dual 加一天
    select sysdate+1/24 from dual 加1小时
    select sysdate+1/(24*60) from dual 加1分钟
    select sysdate+1/(24*60*60) from dual 加1秒钟
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    高级篇之ENC编码器多机位帧同步配置详解
    Java 线程的核心知识
    xstream实现xml和java bean 互相转换
    R语言 数据的整理与清洗(Data Frame 篇下)
    目标检测:VarifocalNet: An IoU-aware Dense Object Detector(CVPR2021)
    HTTPS-各种加密方式
    计算机专业英语词汇
    基于HFSS的T型功分波导设计
    【学习笔记】正则表达式及其在VS Code,Word中查找替换的应用
    一小伙使用 python爬虫来算命?
  • 原文地址:https://blog.csdn.net/m0_67394360/article/details/126113840