fix store procedure
This commit is contained in:
parent
15830ef2ba
commit
f1c546ba8f
5 changed files with 294 additions and 17 deletions
|
|
@ -0,0 +1,140 @@
|
|||
-- ====================================================================
|
||||
-- Fix GetProfileEmployeeSalaryLevel to use calendar arithmetic
|
||||
-- This changes from fixed formulas to actual calendar arithmetic,
|
||||
-- matching calculateGovAge and GetProfileSalaryLevel behavior
|
||||
-- ====================================================================
|
||||
|
||||
DELIMITER $$
|
||||
|
||||
DROP PROCEDURE IF EXISTS `GetProfileEmployeeSalaryLevel`$$
|
||||
|
||||
CREATE DEFINER=`root`@`%` PROCEDURE `GetProfileEmployeeSalaryLevel`(
|
||||
IN personId VARCHAR(36),
|
||||
IN _date DATE
|
||||
)
|
||||
BEGIN
|
||||
WITH ordered AS (
|
||||
SELECT *
|
||||
FROM profileSalary
|
||||
WHERE profileEmployeeId = personId
|
||||
AND commandCode IN ('0','1','2','3','4','8','9','10','11','12','13','14','15','16','20')
|
||||
),
|
||||
work_session AS (
|
||||
SELECT *,
|
||||
COALESCE(
|
||||
SUM(CASE WHEN commandCode IN (12,15,16) THEN 1 ELSE 0 END)
|
||||
OVER (ORDER BY commandDateAffect, commandDateSign
|
||||
ROWS BETWEEN UNBOUNDED PRECEDING AND 1 PRECEDING),
|
||||
0) AS sessionId
|
||||
FROM ordered
|
||||
),
|
||||
session_end AS (
|
||||
SELECT sessionId, MAX(commandDateAffect) AS sessionEndDate
|
||||
FROM work_session
|
||||
GROUP BY sessionId
|
||||
),
|
||||
level_change AS (
|
||||
SELECT *,
|
||||
CASE
|
||||
WHEN LAG(positionCee) OVER (ORDER BY commandDateAffect, commandDateSign) <=> positionCee
|
||||
AND LAG(positionType) OVER (ORDER BY commandDateAffect, commandDateSign) <=> positionType
|
||||
AND LAG(positionLevel) OVER (ORDER BY commandDateAffect, commandDateSign) <=> positionLevel
|
||||
AND LAG(sessionId) OVER (ORDER BY commandDateAffect, commandDateSign) = sessionId
|
||||
THEN 0
|
||||
ELSE 1
|
||||
END AS isNewLevel
|
||||
FROM work_session
|
||||
),
|
||||
level_group AS (
|
||||
SELECT *,
|
||||
SUM(isNewLevel) OVER (ORDER BY commandDateAffect, commandDateSign) AS levelGroup
|
||||
FROM level_change
|
||||
),
|
||||
first_rows AS (
|
||||
SELECT * FROM (
|
||||
SELECT *,
|
||||
ROW_NUMBER() OVER (PARTITION BY levelGroup ORDER BY commandDateAffect, commandDateSign) AS rnLevel
|
||||
FROM level_group
|
||||
) t WHERE rnLevel = 1
|
||||
),
|
||||
rows_with_duration AS (
|
||||
SELECT
|
||||
fr.*,
|
||||
CASE
|
||||
WHEN LEAD(fr.commandDateAffect) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign) IS NULL
|
||||
THEN NULL
|
||||
WHEN LEAD(fr.sessionId) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign) <> fr.sessionId
|
||||
THEN TIMESTAMPDIFF(DAY, fr.commandDateAffect, se.sessionEndDate) + 1
|
||||
ELSE
|
||||
TIMESTAMPDIFF(DAY, fr.commandDateAffect,
|
||||
LEAD(fr.commandDateAffect) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign))
|
||||
END AS duration_days
|
||||
FROM first_rows fr
|
||||
LEFT JOIN session_end se ON se.sessionId = fr.sessionId
|
||||
),
|
||||
resultWithDiff AS (
|
||||
SELECT
|
||||
*,
|
||||
LAG(duration_days) OVER (ORDER BY commandDateAffect, commandDateSign) AS days_diff
|
||||
FROM rows_with_duration
|
||||
)
|
||||
SELECT
|
||||
r.commandDateAffect,
|
||||
r.positionType,
|
||||
r.positionLevel,
|
||||
r.positionCee,
|
||||
r.days_diff,
|
||||
CASE
|
||||
WHEN LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(YEAR, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect)
|
||||
ELSE 0
|
||||
END AS Years,
|
||||
CASE
|
||||
WHEN LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(MONTH, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect) % 12
|
||||
ELSE 0
|
||||
END AS Months,
|
||||
CASE
|
||||
WHEN LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign) IS NOT NULL THEN
|
||||
DATEDIFF(r.commandDateAffect,
|
||||
DATE_ADD(
|
||||
DATE_ADD(LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect) % 12 MONTH)
|
||||
)
|
||||
ELSE 0
|
||||
END AS Days,
|
||||
r.posNo,
|
||||
r.positionExecutive,
|
||||
r.orgRoot,
|
||||
r.orgChild1,
|
||||
r.orgChild2,
|
||||
r.orgChild3,
|
||||
r.orgChild4,
|
||||
r.commandCode,
|
||||
r.commandName,
|
||||
r.commandNo,
|
||||
r.commandYear,
|
||||
r.remark
|
||||
FROM resultWithDiff r
|
||||
|
||||
UNION ALL
|
||||
|
||||
SELECT
|
||||
_date, NULL, NULL, NULL,
|
||||
TIMESTAMPDIFF(DAY, MAX(commandDateAffect), _date) + 1,
|
||||
TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date),
|
||||
TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12,
|
||||
DATEDIFF(_date,
|
||||
DATE_ADD(
|
||||
DATE_ADD(MAX(commandDateAffect),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12 MONTH)
|
||||
),
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL
|
||||
FROM resultWithDiff;
|
||||
|
||||
END$$
|
||||
|
||||
DELIMITER ;
|
||||
|
|
@ -0,0 +1,137 @@
|
|||
-- ====================================================================
|
||||
-- Fix GetProfileEmployeeSalaryPosition to use calendar arithmetic
|
||||
-- This changes from fixed formulas to actual calendar arithmetic,
|
||||
-- matching calculateGovAge and GetProfileSalaryPosition behavior
|
||||
-- ====================================================================
|
||||
|
||||
DELIMITER $$
|
||||
|
||||
DROP PROCEDURE IF EXISTS `GetProfileEmployeeSalaryPosition`$$
|
||||
|
||||
CREATE DEFINER=`root`@`%` PROCEDURE `GetProfileEmployeeSalaryPosition`(
|
||||
IN personId VARCHAR(36),
|
||||
IN _date DATE
|
||||
)
|
||||
BEGIN
|
||||
WITH ordered AS (
|
||||
SELECT * FROM profileSalary WHERE profileEmployeeId = personId AND commandCode IN ('0','1','2','3','4','8','9','10','11','12','13','14','15','16','20')
|
||||
),
|
||||
work_session AS (
|
||||
SELECT *,
|
||||
COALESCE(
|
||||
SUM(CASE WHEN commandCode IN (12,15,16) THEN 1 ELSE 0 END)
|
||||
OVER (ORDER BY commandDateAffect, commandDateSign
|
||||
ROWS BETWEEN UNBOUNDED PRECEDING AND 1 PRECEDING),
|
||||
0) AS sessionId
|
||||
FROM ordered
|
||||
),
|
||||
session_end AS (
|
||||
SELECT sessionId, MAX(commandDateAffect) AS sessionEndDate
|
||||
FROM work_session
|
||||
GROUP BY sessionId
|
||||
),
|
||||
position_change AS (
|
||||
SELECT *,
|
||||
CASE
|
||||
WHEN LAG(positionName) OVER (ORDER BY commandDateAffect, commandDateSign) = positionName
|
||||
AND LAG(sessionId) OVER (ORDER BY commandDateAffect, commandDateSign) = sessionId
|
||||
THEN 0
|
||||
ELSE 1
|
||||
END AS isNewPosition
|
||||
FROM work_session
|
||||
),
|
||||
position_group AS (
|
||||
SELECT *,
|
||||
SUM(isNewPosition) OVER (ORDER BY commandDateAffect, commandDateSign) AS posGroup
|
||||
FROM position_change
|
||||
),
|
||||
first_rows AS (
|
||||
SELECT * FROM (
|
||||
SELECT *,
|
||||
ROW_NUMBER() OVER (PARTITION BY posGroup ORDER BY commandDateAffect, commandDateSign) AS rnPos
|
||||
FROM position_group
|
||||
) t WHERE rnPos = 1
|
||||
),
|
||||
rows_with_duration AS (
|
||||
SELECT
|
||||
fr.*,
|
||||
LEAD(fr.sessionId) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign) AS nextSessionId,
|
||||
CASE
|
||||
WHEN LEAD(fr.commandDateAffect) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign) IS NULL
|
||||
THEN NULL
|
||||
WHEN LEAD(fr.sessionId) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign) <> fr.sessionId
|
||||
THEN TIMESTAMPDIFF(DAY, fr.commandDateAffect, se.sessionEndDate) + 1
|
||||
ELSE
|
||||
TIMESTAMPDIFF(DAY, fr.commandDateAffect,
|
||||
LEAD(fr.commandDateAffect) OVER (ORDER BY fr.commandDateAffect, fr.commandDateSign))
|
||||
END AS duration_days
|
||||
FROM first_rows fr
|
||||
LEFT JOIN session_end se ON se.sessionId = fr.sessionId
|
||||
),
|
||||
resultWithDiff AS (
|
||||
SELECT
|
||||
*,
|
||||
LAG(duration_days) OVER (ORDER BY commandDateAffect, commandDateSign) AS days_diff
|
||||
FROM rows_with_duration
|
||||
)
|
||||
SELECT
|
||||
r.commandDateAffect,
|
||||
r.positionName,
|
||||
r.positionCee,
|
||||
r.days_diff,
|
||||
CASE
|
||||
WHEN LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(YEAR, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect)
|
||||
ELSE 0
|
||||
END AS Years,
|
||||
CASE
|
||||
WHEN LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(MONTH, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect) % 12
|
||||
ELSE 0
|
||||
END AS Months,
|
||||
CASE
|
||||
WHEN LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(DAY,
|
||||
DATE_ADD(
|
||||
DATE_ADD(LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(commandDateAffect) OVER (ORDER BY commandDateAffect, commandDateSign), r.commandDateAffect) % 12 MONTH),
|
||||
r.commandDateAffect)
|
||||
ELSE 0
|
||||
END AS Days,
|
||||
r.posNo,
|
||||
r.positionExecutive,
|
||||
r.positionType,
|
||||
r.positionLevel,
|
||||
r.orgRoot,
|
||||
r.orgChild1,
|
||||
r.orgChild2,
|
||||
r.orgChild3,
|
||||
r.orgChild4,
|
||||
r.commandCode,
|
||||
r.commandName,
|
||||
r.commandNo,
|
||||
r.commandYear,
|
||||
r.remark
|
||||
FROM resultWithDiff r
|
||||
|
||||
UNION ALL
|
||||
|
||||
SELECT
|
||||
_date, NULL, NULL,
|
||||
TIMESTAMPDIFF(DAY, MAX(commandDateAffect), _date) + 1,
|
||||
TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date),
|
||||
TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12,
|
||||
DATEDIFF(_date,
|
||||
DATE_ADD(
|
||||
DATE_ADD(MAX(commandDateAffect),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12 MONTH)
|
||||
),
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL,NULL
|
||||
FROM resultWithDiff;
|
||||
|
||||
END$$
|
||||
|
||||
DELIMITER ;
|
||||
|
|
@ -90,12 +90,12 @@ SELECT
|
|||
END AS Months,
|
||||
CASE
|
||||
WHEN LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(DAY,
|
||||
DATEDIFF(r.commandDateAffect,
|
||||
DATE_ADD(
|
||||
DATE_ADD(LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) MONTH),
|
||||
r.commandDateAffect) + 1
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) % 12 MONTH)
|
||||
)
|
||||
ELSE 0
|
||||
END AS Days,
|
||||
r.posNo,
|
||||
|
|
@ -121,12 +121,12 @@ SELECT
|
|||
TIMESTAMPDIFF(DAY, MAX(commandDateAffect), _date) + 1,
|
||||
TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date),
|
||||
TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12,
|
||||
TIMESTAMPDIFF(DAY,
|
||||
DATEDIFF(_date,
|
||||
DATE_ADD(
|
||||
DATE_ADD(MAX(commandDateAffect),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) MONTH),
|
||||
_date) + 1,
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12 MONTH)
|
||||
),
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL,NULL,NULL
|
||||
FROM resultWithDiff;
|
||||
|
|
|
|||
|
|
@ -94,12 +94,12 @@ SELECT
|
|||
END AS Months,
|
||||
CASE
|
||||
WHEN LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign) IS NOT NULL THEN
|
||||
TIMESTAMPDIFF(DAY,
|
||||
DATEDIFF(r.commandDateAffect,
|
||||
DATE_ADD(
|
||||
DATE_ADD(LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) MONTH),
|
||||
r.commandDateAffect) + 1
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) % 12 MONTH)
|
||||
)
|
||||
ELSE 0
|
||||
END AS Days,
|
||||
r.posNo,
|
||||
|
|
@ -123,12 +123,12 @@ SELECT
|
|||
TIMESTAMPDIFF(DAY, MAX(commandDateAffect), _date) + 1,
|
||||
TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date),
|
||||
TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12,
|
||||
TIMESTAMPDIFF(DAY,
|
||||
DATEDIFF(_date,
|
||||
DATE_ADD(
|
||||
DATE_ADD(MAX(commandDateAffect),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) MONTH),
|
||||
_date) + 1,
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12 MONTH)
|
||||
),
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL
|
||||
FROM resultWithDiff;
|
||||
|
|
|
|||
|
|
@ -96,8 +96,8 @@ SELECT
|
|||
DATE_ADD(
|
||||
DATE_ADD(LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) MONTH),
|
||||
r.commandDateAffect) + 1
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, LAG(r.commandDateAffect) OVER (ORDER BY r.commandDateAffect, r.commandDateSign), r.commandDateAffect) % 12 MONTH),
|
||||
r.commandDateAffect)
|
||||
ELSE 0
|
||||
END AS Days,
|
||||
r.posNo,
|
||||
|
|
@ -124,12 +124,12 @@ SELECT
|
|||
TIMESTAMPDIFF(DAY, MAX(commandDateAffect), _date) + 1,
|
||||
TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date),
|
||||
TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12,
|
||||
TIMESTAMPDIFF(DAY,
|
||||
DATEDIFF(_date,
|
||||
DATE_ADD(
|
||||
DATE_ADD(MAX(commandDateAffect),
|
||||
INTERVAL TIMESTAMPDIFF(YEAR, MAX(commandDateAffect), _date) YEAR),
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) MONTH),
|
||||
_date) + 1,
|
||||
INTERVAL TIMESTAMPDIFF(MONTH, MAX(commandDateAffect), _date) % 12 MONTH)
|
||||
),
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL,NULL
|
||||
FROM resultWithDiff;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue