博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle时间操作结合to_char和to_date使用
阅读量:6234 次
发布时间:2019-06-22

本文共 2158 字,大约阅读时间需要 7 分钟。

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               ) tempwhere 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')

转载地址:http://yqqna.baihongyu.com/

你可能感兴趣的文章
vue-cli3环境变量与分环境打包
查看>>
前端爬坑之旅--echarts渲染时canvas变为100px
查看>>
C#中的Singleton模式
查看>>
git 常用命令
查看>>
在Windows下,用Hexo搭建博客
查看>>
Element组件引发的Vue中mixins使用,写出高复用组件
查看>>
【Linux系统编程】普通用户绑定(bind)特权端口
查看>>
Django搭建个人博客:文章标签功能
查看>>
63. Unique Paths II
查看>>
989-数组形式的整数加法
查看>>
Redis 源码分析之故障转移
查看>>
React as a UI Runtime(四、条件)
查看>>
阿里云MWC 2019发布7款重磅产品,助力全球企业迈向智能化
查看>>
使用Logtail采集Kubernetes上挂载的NAS日志
查看>>
电脑录音软件哪个好,怎么用电脑录音
查看>>
《前端十年-我将一切告诉你》人物关系图
查看>>
angular js中的依赖注入是什么?
查看>>
聊聊 Array 中的坑
查看>>
修改golang源代码获取goroutine id实现ThreadLocal
查看>>
Flutter尝鲜2——动画处理<基础>
查看>>