You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

328 lines
14 KiB

return: text
lang: plpgsql
src: |
DECLARE
result TEXT;
BEGIN
DELETE FROM activite.t_ghm_c
WHERE ghm_id NOT IN (SELECT oid FROM base.t_ghm) AND ghm_id > 0;
UPDATE base.t_ghm SET severite = substr(code,6,1) WHERE severite ='' AND oid <> 0;
-- Standard
UPDATE activite.t_ghm_c SET
ghm_code = t_ghm.code,
ghm_texte = t_ghm.texte,
mco_id = t_mco.oid,
mco_code = t_mco.code,
mco_texte = t_mco.texte,
cas_id = t_ghm.cas_id,
cas_code = t_cas.code,
cas_texte = t_cas.texte,
severite_ghm_id = t_severites_ghm.oid,
severite_ghm_code = t_ghm.severite,
severite_ghm_texte = t_severites_ghm.texte,
cmd_id = t_ghm.cmd_id,
cmd_code = t_cmd.code,
cmd_texte = t_cmd.texte,
ghm5_id = t_ghm.ghm5_id,
ghm5_code = t_ghm5.code,
ghm5_texte = t_ghm5.texte
FROM base.t_ghm
JOIN base.t_cmd ON t_ghm.cmd_id = t_cmd.oid AND t_cmd.code <> '90'
JOIN base.t_mco ON t_mco.code::bpchar = CASE
WHEN t_cmd.code = '28'::bpchar THEN 'S'
WHEN t_ghm.mco = 'M'::bpchar THEN 'M'
WHEN t_ghm.mco = 'C'::bpchar THEN 'C'
WHEN t_ghm.mco = 'O'::bpchar THEN 'O'
ELSE '*' END
JOIN base.t_severites_ghm ON t_ghm.severite = t_severites_ghm.code
JOIN base.t_ghm5 ON t_ghm.ghm5_id = t_ghm5.oid
JOIN base.t_cas ON t_ghm.cas_id = t_cas.oid
WHERE t_ghm.oid = t_ghm_c.ghm_id AND
(
t_ghm_c.ghm_code IS DISTINCT FROM t_ghm.code OR
t_ghm_c.ghm_texte IS DISTINCT FROM t_ghm.texte OR
t_ghm_c.mco_id IS DISTINCT FROM t_mco.oid OR
t_ghm_c.mco_code IS DISTINCT FROM t_mco.code OR
t_ghm_c.mco_texte IS DISTINCT FROM t_mco.texte OR
t_ghm_c.cas_id IS DISTINCT FROM t_ghm.cas_id OR
t_ghm_c.cas_code IS DISTINCT FROM t_cas.code OR
t_ghm_c.cas_texte IS DISTINCT FROM t_cas.texte OR
t_ghm_c.severite_ghm_id IS DISTINCT FROM t_severites_ghm.oid OR
t_ghm_c.severite_ghm_code IS DISTINCT FROM t_ghm.severite OR
t_ghm_c.severite_ghm_texte IS DISTINCT FROM t_severites_ghm.texte OR
t_ghm_c.cmd_id IS DISTINCT FROM t_ghm.cmd_id OR
t_ghm_c.cmd_code IS DISTINCT FROM t_cmd.code OR
t_ghm_c.cmd_texte IS DISTINCT FROM t_cmd.texte OR
t_ghm_c.ghm5_id IS DISTINCT FROM t_ghm.ghm5_id OR
t_ghm_c.ghm5_code IS DISTINCT FROM t_ghm5.code OR
t_ghm_c.ghm5_texte IS DISTINCT FROM t_ghm5.texte
);
INSERT INTO activite.t_ghm_c(
ghm_id,
ghm_code,
ghm_texte,
mco_id,
mco_code,
mco_texte,
cas_id,
cas_code,
cas_texte,
severite_ghm_id,
severite_ghm_code,
severite_ghm_texte,
cmd_id,
cmd_code,
cmd_texte,
ghm5_id,
ghm5_code,
ghm5_texte)
SELECT
t_ghm.oid,
t_ghm.code AS ghm_code,
t_ghm.texte AS ghm_texte,
t_mco.oid AS mco_id,
t_mco.code AS mco_code,
t_mco.texte AS mco_texte,
t_ghm.cas_id,
t_cas.code AS cas_code,
t_cas.texte AS cas_texte,
t_severites_ghm.oid AS severite_ghm_id,
t_ghm.severite AS severite_ghm_code,
t_severites_ghm.texte AS severite_ghm_texte,
t_ghm.cmd_id,
t_cmd.code AS cmd_code,
t_cmd.texte_court AS cmd_texte,
t_ghm.ghm5_id AS ghm5_id,
t_ghm5.code AS ghm5_code,
t_ghm5.texte AS ghm5_texte
FROM base.t_ghm
JOIN base.t_cmd ON t_ghm.cmd_id = t_cmd.oid AND t_cmd.code <> '90'
JOIN base.t_mco ON t_mco.code::bpchar = CASE
WHEN t_cmd.code = '28'::bpchar THEN 'S'
WHEN t_ghm.mco = 'M'::bpchar THEN 'M'
WHEN t_ghm.mco = 'C'::bpchar THEN 'C'
WHEN t_ghm.mco = 'O'::bpchar THEN 'O'
ELSE '*' END
JOIN base.t_severites_ghm ON t_ghm.severite = t_severites_ghm.code
JOIN base.t_ghm5 ON t_ghm.ghm5_id = t_ghm5.oid
JOIN base.t_cas ON t_ghm.cas_id = t_cas.oid
WHERE t_ghm.oid NOT IN (SELECT ghm_id FROM activite.t_ghm_c);
-- Codes spéciaux
UPDATE activite.t_ghm_c SET
ghm_code = t_ghm.code,
ghm_texte = t_ghm.texte,
mco_id = t_mco.oid,
mco_code = t_mco.code,
mco_texte = t_mco.texte,
cas_id = t_cas.oid,
cas_code = t_cas.code,
cas_texte = t_cas.texte,
severite_ghm_id = t_severites_ghm.oid,
severite_ghm_code = t_severites_ghm.code,
severite_ghm_texte = t_severites_ghm.texte,
cmd_id = t_ghm.cmd_id,
cmd_code = t_ghm.cmd_code,
cmd_texte = t_ghm.cmd_texte,
ghm5_id = t_ghm.oid,
ghm5_code = t_ghm.code,
ghm5_texte = t_ghm.texte
FROM (
SELECT -9991 AS oid, '99_SE1' AS code, 'Hors GHM. Forfaits SE1' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9992 AS oid, '99_SE2' AS code, 'Hors GHM. Forfaits SE2' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9993 AS oid, '99_SE3' AS code, 'Hors GHM. Forfaits SE3' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9994 AS oid, '99_SE4' AS code, 'Hors GHM. Forfaits SE4' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9995 AS oid, '99_ATU' AS code, 'Hors GHM. Forfaits ATU' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9996 AS oid, '99_FFM' AS code, 'Hors GHM. Forfaits FFM' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9990 AS oid, '99_ZZZ' AS code, 'Hors GHM. Divers' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9980 AS oid, '98_P' AS code, 'Champ GHM. Présents' AS texte, -9980 AS cmd_id, '98' AS cmd_code, 'Champ GHM. Non groupés' AS cmd_texte, -9980 AS groupe_id, 'ZY' AS groupe_code, 'Champ GHM. Non groupés' AS groupe_texte
UNION
SELECT -9981 AS oid, '98_NG' AS code, 'Champ GHM. Sortis non groupés' AS texte, -9980 AS cmd_id, '98' AS cmd_code, 'Champ GHM. Non groupés' AS cmd_texte, -9980 AS groupe_id, 'ZY' AS groupe_code, 'Champ GHM. Non groupés' AS groupe_texte) t_ghm
JOIN base.t_mco ON t_mco.code = '*'
JOIN base.t_severites_ghm ON t_severites_ghm.code = '*'
JOIN base.t_cas ON t_cas.code = '*'
WHERE t_ghm.oid = t_ghm_c.ghm_id AND
(
t_ghm_c.ghm_code IS DISTINCT FROM t_ghm.code OR
t_ghm_c.ghm_texte IS DISTINCT FROM t_ghm.texte OR
t_ghm_c.mco_id IS DISTINCT FROM t_mco.oid OR
t_ghm_c.mco_code IS DISTINCT FROM t_mco.code OR
t_ghm_c.mco_texte IS DISTINCT FROM t_mco.texte OR
t_ghm_c.cas_id IS DISTINCT FROM t_cas.oid OR
t_ghm_c.cas_code IS DISTINCT FROM t_cas.code OR
t_ghm_c.cas_texte IS DISTINCT FROM t_cas.texte OR
t_ghm_c.severite_ghm_id IS DISTINCT FROM t_severites_ghm.oid OR
t_ghm_c.severite_ghm_code IS DISTINCT FROM t_severites_ghm.code OR
t_ghm_c.severite_ghm_texte IS DISTINCT FROM t_severites_ghm.texte OR
t_ghm_c.cmd_id IS DISTINCT FROM t_ghm.cmd_id OR
t_ghm_c.cmd_code IS DISTINCT FROM t_ghm.cmd_code OR
t_ghm_c.cmd_texte IS DISTINCT FROM t_ghm.cmd_texte OR
t_ghm_c.ghm5_id IS DISTINCT FROM t_ghm.oid OR
t_ghm_c.ghm5_code IS DISTINCT FROM t_ghm.code OR
t_ghm_c.ghm5_texte IS DISTINCT FROM t_ghm.texte
);
INSERT INTO activite.t_ghm_c(
ghm_id,
ghm_code,
ghm_texte,
mco_id,
mco_code,
mco_texte,
cas_id,
cas_code,
cas_texte,
severite_ghm_id,
severite_ghm_code,
severite_ghm_texte,
cmd_id,
cmd_code,
cmd_texte,
ghm5_id,
ghm5_code,
ghm5_texte)
SELECT
t_ghm.oid AS oid,
t_ghm.code AS ghm_code,
t_ghm.texte AS ghm_texte,
t_mco.oid AS mco_id,
t_mco.code AS mco_code,
t_mco.texte AS mco_texte,
t_cas.oid AS cas_id,
t_cas.code AS cas_code,
t_cas.texte AS cas_texte,
t_severites_ghm.oid AS severite_ghm_id,
t_severites_ghm.code AS severite_ghm_code,
t_severites_ghm.texte AS severite_ghm_texte,
t_ghm.cmd_id AS cmd_id,
t_ghm.cmd_code AS cmd_code,
t_ghm.cmd_texte AS cmd_texte,
t_ghm.oid AS ghm5_id,
t_ghm.code AS ghm5_code,
t_ghm.texte AS ghm5_texte
FROM (
SELECT -9991 AS oid, '99_SE1' AS code, 'Hors GHM. Forfaits SE1' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9992 AS oid, '99_SE2' AS code, 'Hors GHM. Forfaits SE2' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9993 AS oid, '99_SE3' AS code, 'Hors GHM. Forfaits SE3' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9994 AS oid, '99_SE4' AS code, 'Hors GHM. Forfaits SE4' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9997 AS oid, '99_SE5' AS code, 'Hors GHM. Forfaits SE5' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9998 AS oid, '99_SE6' AS code, 'Hors GHM. Forfaits SE6' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9995 AS oid, '99_ATU' AS code, 'Hors GHM. Forfaits ATU' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9996 AS oid, '99_FFM' AS code, 'Hors GHM. Forfaits FFM' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9990 AS oid, '99_ZZZ' AS code, 'Hors GHM. Divers' AS texte, -9990 AS cmd_id, '99' AS cmd_code, 'Hors GHM' AS cmd_texte, -9990 AS groupe_id, 'ZZ' AS groupe_code, 'Hors GHM' AS groupe_texte
UNION
SELECT -9980 AS oid, '98_P' AS code, 'Champ GHM. Présents' AS texte, -9980 AS cmd_id, '98' AS cmd_code, 'Champ GHM. Non groupés' AS cmd_texte, -9980 AS groupe_id, 'ZY' AS groupe_code, 'Champ GHM. Non groupés' AS groupe_texte
UNION
SELECT -9981 AS oid, '98_NG' AS code, 'Champ GHM. Sortis non groupés' AS texte, -9980 AS cmd_id, '98' AS cmd_code, 'Champ GHM. Non groupés' AS cmd_texte, -9980 AS groupe_id, 'ZY' AS groupe_code, 'Champ GHM. Non groupés' AS groupe_texte) t_ghm
JOIN base.t_mco ON t_mco.code = '*'
JOIN base.t_severites_ghm ON t_severites_ghm.code = '*'
JOIN base.t_cas ON t_cas.code = '*'
WHERE t_ghm.oid NOT IN (SELECT ghm_id FROM activite.t_ghm_c);
-- Erreurs de groupage
UPDATE activite.t_ghm_c SET
ghm_code = t_ghm.code,
ghm_texte = t_ghm.texte,
mco_id = t_mco.oid,
mco_code = t_mco.code,
mco_texte = t_mco.texte,
cas_id = t_cas.oid,
cas_code = t_cas.code,
cas_texte = t_cas.texte,
severite_ghm_id = t_severites_ghm.oid,
severite_ghm_code = t_severites_ghm.code,
severite_ghm_texte = t_severites_ghm.texte,
cmd_id = t_ghm.cmd_id,
cmd_code = t_cmd.code,
cmd_texte = t_cmd.texte,
ghm5_id = t_ghm.ghm5_id,
ghm5_code = t_ghm5.code,
ghm5_texte = t_ghm5.texte
FROM base.t_ghm
JOIN base.t_cmd ON t_ghm.cmd_id = t_cmd.oid AND t_cmd.code = '90'
JOIN base.t_mco ON t_mco.code = '*'
JOIN base.t_severites_ghm ON t_severites_ghm.code = '*'
JOIN base.t_cas ON t_cas.code = '*'
JOIN base.t_ghm5 ON t_ghm.ghm5_id = t_ghm5.oid
WHERE t_ghm.oid = t_ghm_c.ghm_id AND
(
t_ghm_c.ghm_code IS DISTINCT FROM t_ghm.code OR
t_ghm_c.ghm_texte IS DISTINCT FROM t_ghm.texte OR
t_ghm_c.mco_id IS DISTINCT FROM t_mco.oid OR
t_ghm_c.mco_code IS DISTINCT FROM t_mco.code OR
t_ghm_c.mco_texte IS DISTINCT FROM t_mco.texte OR
t_ghm_c.cas_id IS DISTINCT FROM t_cas.oid OR
t_ghm_c.cas_code IS DISTINCT FROM t_cas.code OR
t_ghm_c.cas_texte IS DISTINCT FROM t_cas.texte OR
t_ghm_c.severite_ghm_id IS DISTINCT FROM t_severites_ghm.oid OR
t_ghm_c.severite_ghm_code IS DISTINCT FROM t_severites_ghm.code OR
t_ghm_c.severite_ghm_texte IS DISTINCT FROM t_severites_ghm.texte OR
t_ghm_c.cmd_id IS DISTINCT FROM t_ghm.cmd_id OR
t_ghm_c.cmd_code IS DISTINCT FROM t_cmd.code OR
t_ghm_c.cmd_texte IS DISTINCT FROM t_cmd.texte OR
t_ghm_c.ghm5_id IS DISTINCT FROM t_ghm.ghm5_id OR
t_ghm_c.ghm5_code IS DISTINCT FROM t_ghm5.code OR
t_ghm_c.ghm5_texte IS DISTINCT FROM t_ghm5.texte
);
INSERT INTO activite.t_ghm_c(
ghm_id,
ghm_code,
ghm_texte,
mco_id,
mco_code,
mco_texte,
cas_id,
cas_code,
cas_texte,
severite_ghm_id,
severite_ghm_code,
severite_ghm_texte,
cmd_id,
cmd_code,
cmd_texte,
ghm5_id,
ghm5_code,
ghm5_texte)
SELECT
t_ghm.oid AS oid,
t_ghm.code AS ghm_code,
t_ghm.texte AS ghm_texte,
t_mco.oid AS mco_id,
t_mco.code AS mco_code,
t_mco.texte AS mco_texte,
t_cas.oid AS cas_id,
t_cas.code AS cas_code,
t_cas.texte AS cas_texte,
t_severites_ghm.oid AS severite_ghm_id,
t_severites_ghm.code AS severite_ghm_code,
t_severites_ghm.texte AS severite_ghm_texte,
t_ghm.cmd_id AS cmd_id,
t_cmd.code AS cmd_code,
t_cmd.texte AS cmd_texte,
t_ghm.ghm5_id AS ghm5_id,
t_ghm5.code AS ghm5_code,
t_ghm5.texte AS ghm5_texte
FROM base.t_ghm
JOIN base.t_cmd ON t_ghm.cmd_id = t_cmd.oid AND t_cmd.code = '90'
JOIN base.t_mco ON t_mco.code = '*'
JOIN base.t_severites_ghm ON t_severites_ghm.code = '*'
JOIN base.t_cas ON t_cas.code = '*'
JOIN base.t_ghm5 ON t_ghm.ghm5_id = t_ghm5.oid
WHERE t_ghm.oid NOT IN (SELECT ghm_id FROM activite.t_ghm_c);
PERFORM base.cti_update_classes('activite', 't_ghm_c', 'GHM','ghm_section');
RETURN 'OK';
END;