Position History

 10 Replies
 1 Subscribed to this topic
 68 Subscribed to this forum
Sort:
Author
Messages
jph826
Advanced Member Send Private Message
Posts: 28
Advanced Member
I need to write a Crystal report that shows each job an employee has ever had, the start date, and the amount of years/mths in that position.  The PAEMPPOS table is difficult to report off of, as there is a position record for every raise, pl/dept or super change.  The HRHISTORY table, FLD NBR 19 has the data, but I'm not sure how to calculate the amount of time in the position.  For example, employee 1000:
Beg Date 10/18/2004, Position 0194
Beg Date 10/21/2007, Position 0171
Beg Date 10/21/2007, Position 0194 (the 0171 must have been a mistake, and a correction was entered on the same date)
Beg Date 9/21/2008, Position 0326
Beg Date  3/24/13, Position 3564
Beg Date  6/1/2013, Position 0194

The report needs to show the Beg Date, the Position and length of time in the position.  If they were in a position more than once, each needs to be listed individually.  Any help would be most appreciated.  Thank you
Mary Porter
Veteran Member Send Private Message
Posts: 337
Veteran Member
Are you using Assignment date in PA13? If so you could use DATE_ASSIGN in the PAEMPPOS table since that doesn't change when salary changes ... it's been helpful for me when I've had to pull that.
jph826
Advanced Member Send Private Message
Posts: 28
Advanced Member
Thanks for your response Mary. I checked, and it doesn't look like we are using that field.
Shane Jones
Veteran Member Send Private Message
Posts: 460
Veteran Member
Not sure if this is what you are looking for but if you have the report sorted ascending by the "Beg_Date" and you use a formula with previous(Beg_Date) it will let you use the previous Beg_Date to calculate the length of time in a position. [The last column shows what you would see with a formula showing previous(Beg_Date).]

Beg Date 9/21/2008, Position 0326, NULL
Beg Date 3/24/13, Position 3564, 9/21/2008
Beg Date 6/1/2013, Position 0194, 3/24/2013

However, to make this work you might want to think a bit about how to do the formulas to adjust for the first and last records and to show the title with the right information. You can use the previous() for other fields to display information on the next line if needed.

Good luck!

Shane Jones
Tools: HR, Payroll, Benefits, PFI, Smart Office, BSI, Portal and Self-Service
Systems: Lawson, Open Hire, Kronos, Crystal Reporting, SumTotal Learning
** Teach others to fish...
Dave Curtis
Veteran Member Send Private Message
Posts: 136
Veteran Member
I have a SQL statement that pulls this type of report. It "cleans up" the repeat records in PAEMPPOS. Are you on Oracle?
PattyG
Advanced Member Send Private Message
Posts: 22
Advanced Member
I would like a copy of the SQL statement please. patriica.goforth@msj.org
Dave Curtis
Veteran Member Send Private Message
Posts: 136
Veteran Member
SELECT jd.company
,jd.employee
,jd.last_name
,jd.first_name
,jd.adj_hire_date
,jd.date_hired
,jd.term_date
,jd.status
,jd.position
,jd.job_code
,jd.title
,jd.process_level
,jd.department
,jd.dept_name
,jd.effect_date
,jd.job_end_date
,ROUND((MONTHS_BETWEEN(NVL(jd.job_end_date,SYSDATE),jd.effect_date))/12,2) as years_in_job
,jd.prev_position
,jd.prev_job_code
,jd.prev_title
,jd.prev_process_level
,jd.prev_department
,jd.prev_dept_name
FROM (SELECT po.*
,CASE WHEN (CASE WHEN po.end_date = to_date('01011700','mm/dd/yyyy') THEN NULL
ELSE (LEAD(po.effect_date, 1)
OVER(PARTITION BY po.employee ORDER BY po.effect_date))-1 END) IS NULL
THEN po.term_date
ELSE (CASE WHEN po.end_date = to_date('01011700','mm/dd/yyyy') THEN NULL
ELSE (LEAD(po.effect_date, 1)
OVER(PARTITION BY po.employee ORDER BY po.effect_date))-1 END) END as job_end_date
FROM (SELECT p.*
,LAG(p.position, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_position
,LAG(p.fte, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_fte
,LAG(p.job_code, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_job_code
,LAG(p.title, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_title
,LAG(p.process_level, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_process_level
,LAG(p.department, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_department
,LAG(p.dept_name, 1) OVER(PARTITION BY p.employee ORDER BY p.effect_date) as prev_dept_name
FROM (SELECT p.company
,p.employee
,trim(e.last_name) as last_name
,trim(e.first_name) as first_name
,e.adj_hire_date
,e.date_hired
,NULLIF(e.term_date, to_date('01011700','mm/dd/yyyy')) as term_date
,e.emp_status as status
,p.position
,p.pos_level
,p.fte
,p.effect_date
,p.end_date
,p.job_code
,j.description as title
,p.process_level
,p.department
,d.r_name as dept_name
FROM paemppos p
JOIN jobcode j ON (p.job_code = j.job_code)
JOIN deptcode d ON (p.process_level = d.process_level AND
p.department = d.department)
JOIN employee e ON (p.employee = e.employee)
WHERE pos_level = 1
ORDER BY p.employee,p.pos_level,p.effect_date) p) po
WHERE po.job_code <> po.prev_job_code
OR po.prev_job_code IS NULL) jd
--Created By Dave Curtis
--Jan-2012
--This SQL statement is intended to be used to pull job history and provide the length of
--time spent in a specific job
--the statement uses PAEMPPOS to pull the history
--The statement is set up to only pull position level 1
Dave Curtis
Veteran Member Send Private Message
Posts: 136
Veteran Member
This is the basic SQL statement used. I alter it as needed, - like when I need to run a report that shows how long someone was in a specific position (defined as in a specific job within a specific department) - then I alter the SQL so the WHERE clause at the bottom is
WHERE (po.process_level <> po.prev_process_level
OR po.prev_process_level IS NULL)
OR (po.department <> po.prev_department
OR po.prev_department IS NULL)
OR (po.job_code <> po.prev_job_code
OR po.prev_job_code IS NULL)

Depending on how you use positions and how/if you use multiple positions, you may also want to change the SQL so it includes position levels other than 1. This can add another level of complexity to it, but it can be altered to pull in multiple positions as well.

Feel free to e-mail me if you have questions about the SQL statement I posted. I would be more than willing to help if I can.

dave.curtis.theq@gmail.com
Attachments
Dave Curtis
Veteran Member Send Private Message
Posts: 136
Veteran Member
PattyG - I tried to e-mail you the statement but my e-mail kept returning the e-mail saying it was not able to deliver the e-mail.
PattyG
Advanced Member Send Private Message
Posts: 22
Advanced Member
can you tell me the table name? patricia.goforth@msj.org

Mis-spelled my name last reply
Dave Curtis
Veteran Member Send Private Message
Posts: 136
Veteran Member
PAEMPPOS is the table