I have the following SQL query:
SELECT t.trans_id, t.business_process_id, tsp.status, tsp.timestamp
FROM tran_stat_p tsp, tran t
WHERE t.trans_id = tsp.trans_id
AND tsp.timestamp BETWEEN '1-jan-2008' AND SYSDATE
AND t.business_process_id = 'ABC01'
It outputs data like this:
trans_ID
business_process_id
status
timestamp
14444400
ABC01
F
6/5/2008 12:37:36 PM
14444400
ABC01
W
6/6/2008 1:37:36 PM
14444400
ABC01
S
6/7/2008 2:37:36 PM
14444400
ABC01
P
6/8/2008 3:37:36 PM
14444401
ABC01
F
6/5/2008 12:37:36 PM
14444401
ABC01
W
6/6/2008 1:37:36 PM
14444401
ABC01
S
6/7/2008 2:37:36 PM
14444401
ABC01
P
6/8/2008 3:37:36 PM
In addition to the above, I'd like to add a column which calculates the time difference (in days) between statuses W&F, S&W, P&S for every unique trans_id
.
The idea is to figure out how long transactions are sitting in the various statuses before they are finally processed to status "P". The life cycle of a transaction is in the following order -> F -> W -> S -> P. Where F is the first status, and P is the final status.
Can anyone help? Thanks in advance.
You can use
LEAD
to retrieve the next timestamp value and calculated the time left in every status (F, W and S) andTRUNC
to calculated days between as an integer :See SQLFIDDLE : http://www.sqlfiddle.com/#!4/04633/49/0