zoukankan      html  css  js  c++  java
  • oracle时间操作结合to_char和to_date使用

    1,按每个10分钟进行分组展示数据

    例如

    有这么一张表 XATXDAY_FLIGHT(航班飞航表),

    有这么一个字段 STD_LOCAL(起飞时间),

    要求:统计一天24小时之内每隔10分钟,这10分钟之内有几架飞机起飞。

    比如:XATXDAY_FLIGHT 表

    STD_LOCAL . . .(其他字段省略)

    12:00

    12:05

    12:10

    12:20

    12:25

    .

    (其他时间省略)

    也就是说,结果应该是这样的:表示12:00~12:10这个时间段内有2架飞机起飞

    12:00~12:10  2

    12:10~12:20  1

    12:20~12:30  2

    查询语句如下:(相当与计算以10分钟分组的行数)

    SELECT count(*) as total,t as 时间段
     from(
           SELECT STD_LOCAL ,
                 CASE  FLOOR((TO_CHAR(TO_DATE(STD_LOCAL,'HH24:MI'),'MI'))/10) 
                 WHEN  0 THEN '0'
                 WHEN  1 THEN '1'
                 WHEN  2 THEN '2'
                 WHEN  3 THEN '3'
                 WHEN  4 THEN '4'
                 WHEN  5 THEN '5'
                 END  as T
           FROM XATXDAY_FLIGHT
                   ) temp
    
    where to_char(sysdate,'dd') = to_char(to_date(STD_LOCAL,'yyyy-mm-dd hh24:mi:ss'),'dd')--只展示当天
     GROUP BY TO_CHAR(TO_DATE(temp.STD_LOCAL,'HH24:MI'),'HH24'),temp.T
     order by TO_CHAR(TO_DATE(temp.STD_LOCAL,'HH24:MI'),'HH24'),temp.T

    2,按小时进行比较

    to_char(to_date(t.create_time,'yyyy-mm-dd hh24:mi:ss'),'yyyy-mm-dd') = to_char(sysdate,'yyyy-mm-dd');

    1),先把字符串create_time转成标准日期格式,假如字符串create_time只有年月日,那么就转转成to_date(create_time,'yyyy-mm-dd')。主要看create_time是什么格式

    2),再转换精确到年月日:yyyy-mm-dd,进行字符串的比较,比如>,<,=

    3,按小时显示时间

    select to_char(sysdate,'hh24') from dual;//09,就表示早上9点;21,就表示晚上9点

    4,查询当天数据

    日报数据统计中会用到当天数据的查询,下列就是日期要对应的条件:

    between
    to_date(to_char(sysdate,'yyyy-mm-dd') || ' 00:00:01','yyyy-mm-dd hh24:mi:ss') and
    to_date(to_char(sysdate,'yyyy-mm-dd') || ' 23:59:59','yyyy-mm-dd hh24:mi:ss');

    字段类型为varchar2,格式要与格式化的样式匹配

    复制代码
    当天
    select * from 表名 where to_char(to_date(字段名,'yyyy-mm-dd hh24:mi:ss'),'yyyymmdd')=to_char(sysdate,'yyyymmdd')
    当周
    select * from 表名 where to_char(to_date(字段名,'yyyy-mm-dd hh24:mi:ss'),'iw')=to_char(sysdate,'iw')
    当月
    select * from 表名 where to_char(to_date(字段名,'yyyy-mm-dd hh24:mi:ss'),'mm')=to_char(sysdate,'mm')
    当季度
    select * from 表名 where to_char(to_date(字段名,'yyyy-mm-dd hh24:mi:ss'),'q')=to_char(sysdate,'q')
    复制代码

    字段类型为date

    复制代码
    当天
    select * from 表名 where to_char(字段名,'dd')=to_char(sysdate,'yyyymmdd')
    当周
    select * from 表名 where to_char(字段名,'iw')=to_char(sysdate,'iw')
    当月
    select * from 表名 where to_char(字段名,'mm')=to_char(sysdate,'mm')
    当季度
    select * from 表名 where to_char(字段名,'q')=to_char(sysdate,'q')
    复制代码
  • 相关阅读:
    groovy Date 格式化
    MySql Delete不走索引问题
    java解析文件
    H5自动准备杂记
    ubuntu 安装php ,apache 问题总结
    git 添加已被忽略的文件夹
    jenkins + nodejs + git 自动化部署前端
    分享到微信填坑之路
    jenkins 自动化部署php
    natapp 穿透访问 vue项目 Invalid Host header
  • 原文地址:https://www.cnblogs.com/nizuimeiabc1/p/8525010.html
Copyright © 2011-2022 走看看