Hello
I just found something fun and maybe useful to do in OBIEE. Calculating the difference between timestamps is pretty easy by using timestamp diff function. When it comes to calculating the difference between month, I know 'sql_tsi_month' can be used, which will give you results in month. However, you don't always want to put date columns into the equation if your report is aggregating at monthly level, and sometimes the date column is simply not available. So how do you go about calculating the difference in month.
To show the point, let's look at the following report to understand the requirement:
We need to calculate the difference in month between check in date and KPI month and year
So in this case, the report is going against the monthly aggregate fact since the date dimension field is KPI month and year, we don't want to introduce KPI Date into the formula (even if we do have this field) for comparing timestamps. So we need a way to figure out the difference between (in this case) 3/08/2010 and 201101 in months. Now the good new is that, it can be a rounded estimate, meaning that as long as the date is in March, any date between 1 to 31, it is March. So the difference between March 31th and April 1st is 1 month. This is a good news, because it basically means I need to mathematically calculate the difference between something like 201003 and 201101, but the result should be in month.
Now let's figure out how to achieve this mathematically.
We all know that 201101 - 201003 = 98. Obviously this is going to be wrong. In order to do the right calculation, we need to calculate this in two parts: 2011 - 2010 and 01 - 03, then add the result back together to give the final result.
Now let's break it down step by step:
1. Assign KPI Month (201101) is X and Check in Date (201003) is Y.
2. do: X/100 and round off, this will give you something like 2011 and Y/100 will be 2010.
3. Divide the above and multiply by 12 since there are 12 months in a year. In this case, it will give you 1*12 = 12.
4. Do: X- (X/100)*100 and Y - (Y/100)*100. Both will give you the last 2 digits: 03 and 01.
5. Divide the two numbers from step 4, this will give you difference in month, which is -2.
6. Now add the result from step 5 and step 3, which is then -2+12 = 10. This is your answer.
Now the programming of this in OBIEE is very simple. You convert the data from 03/08/2010 into numeric 201003, the formula of achieving such becomes your 'Y'. And the rest are basically the exact carry-out of what has been described above, so I will skip both of the steps and just show you the result.
Defining the OBIEE formula:
Result (and it's working):
Thanks
Until next time
I just found something fun and maybe useful to do in OBIEE. Calculating the difference between timestamps is pretty easy by using timestamp diff function. When it comes to calculating the difference between month, I know 'sql_tsi_month' can be used, which will give you results in month. However, you don't always want to put date columns into the equation if your report is aggregating at monthly level, and sometimes the date column is simply not available. So how do you go about calculating the difference in month.
To show the point, let's look at the following report to understand the requirement:
We need to calculate the difference in month between check in date and KPI month and year
So in this case, the report is going against the monthly aggregate fact since the date dimension field is KPI month and year, we don't want to introduce KPI Date into the formula (even if we do have this field) for comparing timestamps. So we need a way to figure out the difference between (in this case) 3/08/2010 and 201101 in months. Now the good new is that, it can be a rounded estimate, meaning that as long as the date is in March, any date between 1 to 31, it is March. So the difference between March 31th and April 1st is 1 month. This is a good news, because it basically means I need to mathematically calculate the difference between something like 201003 and 201101, but the result should be in month.
Now let's figure out how to achieve this mathematically.
We all know that 201101 - 201003 = 98. Obviously this is going to be wrong. In order to do the right calculation, we need to calculate this in two parts: 2011 - 2010 and 01 - 03, then add the result back together to give the final result.
Now let's break it down step by step:
1. Assign KPI Month (201101) is X and Check in Date (201003) is Y.
2. do: X/100 and round off, this will give you something like 2011 and Y/100 will be 2010.
3. Divide the above and multiply by 12 since there are 12 months in a year. In this case, it will give you 1*12 = 12.
4. Do: X- (X/100)*100 and Y - (Y/100)*100. Both will give you the last 2 digits: 03 and 01.
5. Divide the two numbers from step 4, this will give you difference in month, which is -2.
6. Now add the result from step 5 and step 3, which is then -2+12 = 10. This is your answer.
Now the programming of this in OBIEE is very simple. You convert the data from 03/08/2010 into numeric 201003, the formula of achieving such becomes your 'Y'. And the rest are basically the exact carry-out of what has been described above, so I will skip both of the steps and just show you the result.
Defining the OBIEE formula:
Result (and it's working):
Thanks
Until next time