服务器之家

服务器之家 > 正文

oracle 取某个时间段的数据(每周几的上午几点到几点)

时间:2020-04-18 16:32     来源/作者:棒棒糖_26

oracle 取某个时间段的数据,具体代码如下所示:

?
1
2
3
4
5
6
7
8
9
10
11
12
select count(*),t.分组字段 from (
select t.* ,to_char(t.时间,'HH24') stime,to_char(t.时间,'HH24mi') fz,to_char(时间,'d')
from A t
where 时间>=to_date('2019-12-01','yyyy-MM-dd') and ghsj<=to_date('2019-12-31','yyyy-MM-dd') and to_char(时间,'d')='2'
) where stime in ('08','09','10','11','12') and fz>=0800 a
group by T.分组字段
 
to_char(时间,'d') 取当前时间是星期几 每星期第一天为周日
 
to_char(t.时间,'HH24mi') 取当前时间的小时分
 
o_char(t.时间,'HH24') 取当前时间的小时

ps:oracle 同一个数据有多条记录,根据条件取时间最大的那一条

1.第一种方式

?
1
select max(t1.INVALID_TIME) from T_CUSTOMER t1 where t1.customer_code = '5101'

1.第二种方式

?
1
SELECT INVALID_TIME FROM (SELECT * FROM T_CUSTOMER WHERE customer_code='5101' ORDER BY INVALID_TIME desc) WHERE ROWNUM =1

1.第三种方式

?
1
select INVALID_TIME from T_CUSTOMER t where INVALID_TIME=(select max(INVALID_TIME) from T_CUSTOMER where customer_code='5101') and ROWNUM =1

5.不过滤存在多条最大时间

?
1
select INVALID_TIME from T_CUSTOMER t wheret.INVALID_TIME = (select max(t1.INVALID_TIME) from T_CUSTOMER t1 where t1.customer_code = '5101')

总结

以上所述是小编给大家介绍的oracle 取某个时间段的数据(每周几的上午几点到几点),希望对大家有所帮助!

原文链接:https://www.cnblogs.com/chenxiaoyao/archive/2020/01/03/12145813.html

标签:

相关文章

热门资讯

沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
返回顶部