Thursday, 11 April 2013

A Log File Switch Frequency Query

select to_char(first_time,'YYYY-MON-DD') day,
to_char(sum(decode(to_char(

first_time,'HH24'),'00',1,0)),'999') "00",
to_char(sum(decode(to_char(
first_time,'HH24'),'01',1,0)),'999') "01",
to_char(sum(decode(to_char(
first_time,'HH24'),'02',1,0)),'999') "02",
to_char(sum(decode(to_char(
first_time,'HH24'),'03',1,0)),'999') "03",
to_char(sum(decode(to_char(
first_time,'HH24'),'04',1,0)),'999') "04",
to_char(sum(decode(to_char(
first_time,'HH24'),'05',1,0)),'999') "05",
to_char(sum(decode(to_char(
first_time,'HH24'),'06',1,0)),'999') "06",
to_char(sum(decode(to_char(
first_time,'HH24'),'07',1,0)),'999') "07",
to_char(sum(decode(to_char(
first_time,'HH24'),'08',1,0)),'999') "08",
to_char(sum(decode(to_char(
first_time,'HH24'),'09',1,0)),'999') "09",
to_char(sum(decode(to_char(
first_time,'HH24'),'10',1,0)),'999') "10",
to_char(sum(decode(to_char(
first_time,'HH24'),'11',1,0)),'999') "11",
to_char(sum(decode(to_char(
first_time,'HH24'),'12',1,0)),'999') "12",
to_char(sum(decode(to_char(
first_time,'HH24'),'13',1,0)),'999') "13",
to_char(sum(decode(to_char(
first_time,'HH24'),'14',1,0)),'999') "14",
to_char(sum(decode(to_char(
first_time,'HH24'),'15',1,0)),'999') "15",
to_char(sum(decode(to_char(
first_time,'HH24'),'16',1,0)),'999') "16",
to_char(sum(decode(to_char(
first_time,'HH24'),'17',1,0)),'999') "17",
to_char(sum(decode(to_char(
first_time,'HH24'),'18',1,0)),'999') "18",
to_char(sum(decode(to_char(
first_time,'HH24'),'19',1,0)),'999') "19",
to_char(sum(decode(to_char(
first_time,'HH24'),'20',1,0)),'999') "20",
to_char(sum(decode(to_char(
first_time,'HH24'),'21',1,0)),'999') "21",
to_char(sum(decode(to_char(
first_time,'HH24'),'22',1,0)),'999') "22",
to_char(sum(decode(to_char(
first_time,'HH24'),'23',1,0)),'999') "23",
count(*) as daytotal
from v$log_history
group by to_char(first_time,'YYYY-MON-
DD') order by 1;

Wednesday, 3 April 2013

INTERVAL and TIMESTAMP conversions


A short one today all about dates and differences.

I recently had cause to report off a table (lots of dynamic real-time stuff) where there was a column defined as TIMESTAMP(6) WITH TIME ZONE.

Unfortunately OBIEE doesn't seem to understand this too well, and anyway all I'm interested in is the date and time, all the timezone stuff is not required for reporting (phew).

There is a way to change the TIMESTAMP(6) WITH TIME ZONE column to a date and it passes a couple of the best practice tests, mainly that it is performed in the database, as far back down the chain as possible and secondly that no new invented code is used, only existing Oracle functionality.

The column in question is LOG_DATE defined as TIMESTAMP(6) WITH TIME ZONE, and to change this to a date column use CAST.

CAST (log_date AS DATE) AS log_date

As the command is fairly self explanatory, I'll stop here.

How can I get the time difference from an INTERVAL DAY TO SECOND column?

Push the requirement back to the database if possible and we will use a 'trick' of SQL and dates to return a number result as if we had subtracted one date from the other. I'll leave the different calculations you may need to get the difference in hours etc... What I was interested in was the difference in seconds.

Assuming that the column in question is RUN_DURATION and has been defined as INTERVAL DAY(3) TO SECOND(2)

Aside/hint: We can add an interval to a date and the answer is date.

We will add the interval to a date and then subtract the date, yes I know it sounds like one of those trick mathematical quizzes that children are so fond of.

our RUN_DURATION is wrapped as follows

(SYSDATE+RUN_DURATION-SYSDATE)*86400 AS RUN_DURATION

The answer is given as the difference between two dates as standard in Oracle where 12 hours is 0.5 of a day. Multiplying the answer by 86400 gives me the answer in seconds.