Oracle时间处理和报表分时段统计

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/gghh2015/article/details/76603795

以下是在报表工具中的sql的写法:

1、之前做的报表,有一张需要展现为分时段统计,就是8-9点,9-10点各项的数据为多少。

2、这里需要在查出各类数据的同时也把数据里的时间查询出来,当然要处理一下,时间要做两步处理,一个把时间转换成日期,一个把时间转换成小时,最后所有的数据按日期和小时分组。

3、关于时间格式转换成日期和小时,需要用到to_char()函数,to_char(time, 'yyyy-mm-dd')可以把时间转成日期,to_char(time, 'hh24')把时间转换成小时。但是这里的time要求是date类型。

4、关于时间,我们存储为字符串形式,这样就不能直接转换,而且oracle的时间格式和java的不一样,

java表示年月日时分秒:yyyy-MM-dd HH:mm:ss,如果是12小时制,则为:yyyy-MM-dd hh:mm:ss

oracle表示年月日时分秒:yyyy-MM-dd hh24:mi:ss

5、最终,时间的两步处理为:

转成日期:to_char(TO_DATE('2017-08-01 00:00:00', 'yyyy-MM-dd hh24:mi:ss'),'yyyy-mm-dd')

转成小时:to_char(TO_DATE('2017-08-01 00:00:00', 'yyyy-MM-dd hh24:mi:ss'),'hh24')


下面是java中的时间处理:

1、获取当前时间 Date now = new Date();

2、时间字符串转Date(要处理异常) :

String time = "2017-10-31 19:06:00";

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //MM月,mm分钟

Date date = sdf.parse(time);

3、Date转字符串

Date date = new Date();

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 

String createdate = sdf.format(date);


下面是oracle秒转时分秒函数:

CREATE OR REPLACE FUNCTION FormatTime
(
inTime NUMBER
)RETURN VARCHAR2
AS
v_Time NUMBER(10);
tValue NUMBER(4);
tStrTime VARCHAR2(10);

BEGIN

-- RETURN TO_CHAR(ROUND(inTime, 1));
IF inTime > 10000*3600 THEN
tStrTime := '9999:59:59';
RETURN tStrTime;
ELSIF inTime <= 0 THEN
tStrTime := '0:00:00';
RETURN tStrTime;
END IF;
v_Time := inTime;

tStrTime := to_char(floor(v_Time/3600))||':';

tValue := floor(MOD(v_Time,3600)/60);
IF tValue<10 THEN
tStrTime := tStrTime ||'0'||to_char(tValue)||':';
ELSE
tStrTime := tStrTime ||to_char(tValue)||':';
END IF;

tValue := MOD(v_Time,60);
IF tValue<10 THEN
tStrTime := tStrTime ||'0'||to_char(tValue);
ELSE
tStrTime := tStrTime ||to_char(tValue);
END IF;

RETURN tStrTime;

END FormatTime;

展开阅读全文

没有更多推荐了,返回首页