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.
 
 

1123 lines
47 KiB

return: text
lang: plpgsql
src: |
DECLARE
result TEXT;
_module_pmsimco TEXT;
_with_rubrique TEXT;
_with_prestation TEXT;
_with_acte TEXT;
BEGIN
RAISE NOTICE '%' , 'Initialisation poles';
-- Contenu table
INSERT INTO base.t_pole (oid, code, texte, texte_court)
SELECT 0, '**', 'Non renseigné', 'Non renseigné'
WHERE 0 NOT IN (SELECT oid FROM base.t_pole);
IF (SELECT count(*) FROM base.t_pole WHERE oid > 0) = 0 THEN
RETURN 'OK. Aucun pole';
END IF;
-- replication dans activite
TRUNCATE activite.t_pole;
INSERT INTO activite.t_pole (oid, code, texte, texte_court, section_id, section_code, section_texte)
SELECT oid, code, texte, texte_court, section_id, section_code, section_texte
FROM base.t_pole
;
RAISE NOTICE '%' , 'Preparation mouvemennts';
DROP TABLE IF EXISTS w_sejour_lieu;
CREATE TEMP TABLE w_sejour_lieu AS
SELECT p_mouvements_sejour.no_sejour, p_mouvements_sejour.lieu_id
FROM activite.p_mouvements_sejour
GROUP BY 1,2
;
ANALYSE w_sejour_lieu
;
CREATE INDEX i_w_sejour_lieu_no_sejour
ON w_sejour_lieu
USING btree
(no_sejour COLLATE pg_catalog."default");
CREATE INDEX i_w_sejour_lieu_lieu_id
ON w_sejour_lieu
USING btree
(lieu_id);
INSERT INTO w_sejour_lieu (no_sejour, lieu_id)
SELECT p_sejours.no_sejour, p_sejours.lieu_sortie_id
FROM activite.p_sejours
LEFT JOIN w_sejour_lieu ON
p_sejours.no_sejour = w_sejour_lieu.no_sejour AND
p_sejours.lieu_sortie_id = w_sejour_lieu.lieu_id
WHERE w_sejour_lieu.lieu_id IS NULL
GROUP BY 1,2
;
INSERT INTO w_sejour_lieu (no_sejour, lieu_id)
SELECT p_factures.no_sejour, p_factures_lignes_c.lieu_id
FROM activite.p_factures_lignes_c
JOIN activite.p_factures ON p_factures.no_facture = p_factures_lignes_c.no_facture
LEFT JOIN w_sejour_lieu ON
p_factures.no_sejour = w_sejour_lieu.no_sejour AND
p_factures_lignes_c.lieu_id = w_sejour_lieu.lieu_id
WHERE w_sejour_lieu.lieu_id IS NULL
GROUP BY 1,2
;
INSERT INTO w_sejour_lieu (no_sejour, lieu_id)
SELECT p_factures.no_sejour, p_factures_lignes_h.lieu_id
FROM activite.p_factures_lignes_h
JOIN activite.p_factures ON p_factures.no_facture = p_factures_lignes_h.no_facture
LEFT JOIN w_sejour_lieu ON
p_factures.no_sejour = w_sejour_lieu.no_sejour AND
p_factures_lignes_h.lieu_id = w_sejour_lieu.lieu_id
WHERE w_sejour_lieu.lieu_id IS NULL
GROUP BY 1,2
;
RAISE NOTICE '%' , 'Application des regles';
-- pmsi mco ?
_module_pmsimco = '0';
IF EXISTS (SELECT * FROM pg_tables WHERE schemaname = 'pmsi' AND tablename = 'p_rss') THEN
IF (SELECT count(*)
FROM activite.t_pole_rule
WHERE liste_ghm <> '' OR
COALESCE(liste_sauf_ghm,'') <> '' OR
COALESCE(liste_diagnostic_principal,'') <> '' OR
COALESCE(liste_diagnostic_relie,'') <> '' OR
COALESCE(liste_diagnostic_associe,'') <> '' OR
COALESCE(liste_acte,'') <> '') > 1 THEN
_module_pmsimco = '1';
RAISE NOTICE '%' , 'Application des regles. Avec PMSI MCO';
END IF;
END IF;
-- Rubriques ?
_with_rubrique = '0';
IF (SELECT count(*)
FROM activite.t_pole_rule
WHERE COALESCE(liste_rubrique,'') <> ''
) > 1 THEN
_with_rubrique = '1';
END IF;
_with_prestation = '0';
IF (SELECT count(*)
FROM activite.t_pole_rule
WHERE COALESCE(liste_prestation,'') <> '' OR
COALESCE(liste_sauf_prestation,'') <> ''
) > 1 THEN
_with_prestation = '1';
END IF;
_with_acte = '0';
IF (SELECT count(*)
FROM activite.t_pole_rule
WHERE COALESCE(liste_acte,'') <> ''
) > 1 THEN
_with_acte = '1';
END IF;
-- Sejours et RSS à Traiter
RAISE NOTICE '%' , 'Application des regles. Identification des sejours';
DROP SEQUENCE IF EXISTS w_sejours_rss_sequence;
CREATE SEQUENCE w_sejours_rss_sequence;
DROP TABLE IF EXISTS w_sejours_rss;
IF _module_pmsimco = '1' THEN
-- si pmsi mco
CREATE TEMP TABLE w_sejours_rss AS
SELECT
nextval('w_sejours_rss_sequence'::regclass) AS oid,
COALESCE(t_finess.oid,0) AS finess_id,
p_sejours.oid AS sejour_id,
p_sejours.no_sejour AS no_sejour,
COALESCE(p_rss.oid,0) AS rss_id,
diagnostic_principal_id,
diagnostic_relie_id,
NULL::bigint[] AS diagnostic_associe_liste_rule_id,
NULL::bigint[] AS acte_liste_rule_id,
NULL::bigint[] AS prestation_liste_rule_id,
NULL::bigint[] AS rubrique_liste_rule_id,
p_rss.ghm_id AS ghm_pmsi_id,
p_sejours.ghm_id AS ghm_activite_id,
COALESCE(medecin_rss_id,0) AS medecin_rss_id,
medecin_sejour_id,
COALESCE(t_medecins_pmsi.specialite_id,0) AS specialite_rss_id,
COALESCE(t_medecins_base.specialite_id,0) AS specialite_sejour_id,
p_sejours.type_sejour,
w_sejour_lieu.lieu_id,
t_lieux_c.unite_fonctionnelle_id,
t_lieux_c.service_facturation_id,
t_lieux_c.etage_id,
t_lieux_c.activite_id,
0::bigint AS pole_id,
0::bigint AS pole_priorite
FROM activite.p_sejours
JOIN w_sejour_lieu ON p_sejours.no_sejour = w_sejour_lieu.no_sejour
JOIN activite.t_lieux_c ON w_sejour_lieu.lieu_id = t_lieux_c.oid
LEFT JOIN pmsi.p_rss ON no_sejour_administratif = p_sejours.no_sejour AND p_sejours.date_sortie = p_rss.date_sortie AND p_rss.etat = ''
LEFT JOIN pmsi.t_medecins t_medecins_pmsi ON medecin_rss_id = t_medecins_pmsi.oid
LEFT JOIN activite.t_medecins_administratifs ON medecin_sejour_id = t_medecins_administratifs.oid
LEFT JOIN base.t_medecins t_medecins_base ON t_medecins_administratifs.medecin_id = t_medecins_base.oid
LEFT JOIN base.t_finess ON p_sejours.finess = t_finess.code;
UPDATE w_sejours_rss SET
medecin_rss_id = t_medecins.oid,
specialite_rss_id = t_medecins.specialite_id
FROM activite.t_medecins_administratifs_c
JOIN pmsi.t_medecins ON t_medecins_administratifs_c.adm_code = t_medecins.code
WHERE medecin_sejour_id = t_medecins_administratifs_c.oid AND
t_medecins.oid <> 0 AND
(t_medecins.oid IS DISTINCT FROM medecin_rss_id OR
specialite_rss_id IS DISTINCT FROM t_medecins.specialite_id)
;
ELSE
-- si pas pmsi mco
CREATE TEMP TABLE w_sejours_rss AS
SELECT
nextval('w_sejours_rss_sequence'::regclass) AS oid,
COALESCE(t_finess.oid,0) AS finess_id,
p_sejours.oid AS sejour_id,
p_sejours.no_sejour AS no_sejour,
0 AS rss_id,
0::bigint AS diagnostic_principal_id,
0::bigint AS diagnostic_relie_id,
NULL::bigint[] AS diagnostic_associe_liste_rule_id,
NULL::bigint[] AS acte_liste_rule_id,
NULL::bigint[] AS prestation_liste_rule_id,
NULL::bigint[] AS rubrique_liste_rule_id,
0::bigint AS ghm_pmsi_id,
p_sejours.ghm_id AS ghm_activite_id,
0 AS medecin_rss_id,
medecin_sejour_id,
0 AS specialite_rss_id,
COALESCE(t_medecins_base.specialite_id,0) AS specialite_sejour_id,
p_sejours.type_sejour,
w_sejour_lieu.lieu_id,
t_lieux_c.unite_fonctionnelle_id,
t_lieux_c.service_facturation_id,
t_lieux_c.etage_id,
t_lieux_c.activite_id,
0::bigint AS pole_id,
0::bigint AS pole_priorite
FROM activite.p_sejours
JOIN w_sejour_lieu ON p_sejours.no_sejour = w_sejour_lieu.no_sejour
JOIN activite.t_lieux_c ON w_sejour_lieu.lieu_id = t_lieux_c.oid
LEFT JOIN base.t_finess ON p_sejours.finess = t_finess.code
LEFT JOIN activite.t_medecins_administratifs ON medecin_sejour_id = t_medecins_administratifs.oid
LEFT JOIN base.t_medecins t_medecins_base ON t_medecins_administratifs.medecin_id = t_medecins_base.oid
;
END IF;
-- GHM sur services non MCO
-- Verrouillé pour l'instant (on verra par la suite)
-- UPDATE w_sejours_rss SET
-- ghm_pmsi_id = 0,
-- ghm_activite_id = 0
-- FROM activite.t_services_facturation
-- WHERE service_facturation_id = t_services_facturation .oid AND
-- type_t2a <> '1' AND
-- service_facturation_id <> 0 AND
-- (ghm_pmsi_id > 0 OR
-- ghm_activite_id > 0)
-- ;
--
UPDATE w_sejours_rss SET
medecin_rss_id = 0,
specialite_rss_id = 0
WHERE medecin_sejour_id <> 0 AND
(medecin_rss_id <> 0 OR specialite_rss_id <> 0);
UPDATE w_sejours_rss
SET finess_id = (SELECT MAX(finess_id) FROM w_sejours_rss WHERE finess_id <> 0)
WHERE finess_id = 0 AND (SELECT MAX(finess_id) FROM w_sejours_rss WHERE finess_id <> 0) <> 0;
UPDATE w_sejours_rss
SET finess_id = (SELECT MAX(oid) FROM base.t_finess)
WHERE finess_id = 0;
CREATE INDEX w_sejours_rss_i0 ON w_sejours_rss USING btree (oid);
CREATE INDEX w_sejours_rss_i1 ON w_sejours_rss USING btree (rss_id);
CREATE INDEX w_sejours_rss_i2 ON w_sejours_rss USING btree (sejour_id);
CREATE INDEX w_sejours_rss_i3 ON w_sejours_rss USING btree (no_sejour);
-- Traduction des règles en oid
RAISE NOTICE '%' , 'Application des regles. Traduction en oid';
DROP TABLE IF EXISTS w_pole_rule;
CREATE TEMP TABLE w_pole_rule AS
SELECT
t_pole_rule.oid,
pole_id,
CASE WHEN priorite <> 0 THEN priorite WHEN liste_diagnostic_principal <> '' THEN 90000 ELSE 999999 END AS priorite,
CASE WHEN liste_finess <> '' THEN '1' ELSE '0' END AS a_liste_finess,
string_to_array(translate(liste_finess,'*,','% '),' ') AS liste_finess,
NULL::bigint[] AS liste_finess_id ,
CASE WHEN liste_diagnostic_principal <> '' THEN '1' ELSE '0' END AS a_liste_diagnostic_principal,
string_to_array(translate(liste_diagnostic_principal,'*,','% '),' ') AS liste_diagnostic_principal,
NULL::bigint[] AS liste_diagnostic_principal_id ,
CASE WHEN liste_diagnostic_relie <> '' THEN '1' ELSE '0' END AS a_liste_diagnostic_relie,
string_to_array(translate(liste_diagnostic_relie,'*,','% '),' ') AS liste_diagnostic_relie,
NULL::bigint[] AS liste_diagnostic_relie_id ,
CASE WHEN liste_diagnostic_associe <> '' THEN '1' ELSE '0' END AS a_liste_diagnostic_associe,
string_to_array(translate(liste_diagnostic_associe,'*,','% '),' ') AS liste_diagnostic_associe,
NULL::bigint[] AS liste_diagnostic_associe_id ,
CASE WHEN liste_acte <> '' THEN '1' ELSE '0' END AS a_liste_acte,
string_to_array(translate(liste_acte,'*,','% '),' ') AS liste_acte,
NULL::bigint[] AS liste_acte_pmsi_id ,
NULL::bigint[] AS liste_acte_base_id ,
CASE WHEN liste_ghm <> '' THEN '1' ELSE '0' END AS a_liste_ghm,
string_to_array(translate(liste_ghm,'*,','% '),' ') AS liste_ghm,
NULL::bigint[] AS liste_ghm_pmsi_id,
NULL::bigint[] AS liste_ghm_activite_id,
liste_ghm AS liste_ghm_origine,
CASE WHEN liste_sauf_ghm <> '' THEN '1' ELSE '0' END AS a_liste_sauf_ghm,
string_to_array(translate(liste_sauf_ghm,'*,','% '),' ') AS liste_sauf_ghm,
NULL::bigint[] AS liste_sauf_ghm_pmsi_id ,
NULL::bigint[] AS liste_sauf_ghm_activite_id ,
liste_sauf_ghm AS liste_sauf_ghm_origine,
CASE WHEN liste_type_sejour <> '' THEN '1' ELSE '0' END AS a_liste_type_sejour,
string_to_array(translate(liste_type_sejour,'*,','% '),' ') AS liste_type_sejour,
NULL::text[] AS liste_type_sejour_id ,
CASE WHEN liste_unite_fonctionnelle <> '' THEN '1' ELSE '0' END AS a_liste_unite_fonctionnelle,
string_to_array(translate(liste_unite_fonctionnelle,'*,','% '),' ') AS liste_unite_fonctionnelle,
NULL::bigint[] AS liste_unite_fonctionnelle_id ,
CASE WHEN liste_service <> '' THEN '1' ELSE '0' END AS a_liste_service,
string_to_array(translate(liste_service,'*,','% '),' ') AS liste_service,
NULL::bigint[] AS liste_service_id ,
CASE WHEN liste_etage <> '' THEN '1' ELSE '0' END AS a_liste_etage,
string_to_array(translate(liste_etage,'*,','% '),' ') AS liste_etage,
NULL::bigint[] AS liste_etage_id ,
CASE WHEN liste_activite <> '' THEN '1' ELSE '0' END AS a_liste_activite,
string_to_array(translate(liste_activite,'*,','% '),' ') AS liste_activite,
NULL::bigint[] AS liste_activite_id ,
CASE WHEN liste_medecin <> '' THEN '1' ELSE '0' END AS a_liste_medecin,
string_to_array(CASE WHEN liste_medecin NOT LIKE '%**%' THEN translate(liste_medecin,'*,','% ') ELSE liste_medecin END,' ') AS liste_medecin,
NULL::bigint[] AS liste_medecin_pmsi_id ,
NULL::bigint[] AS liste_medecin_activite_id ,
CASE WHEN liste_specialite <> '' THEN '1' ELSE '0' END AS a_liste_specialite,
string_to_array(translate(liste_specialite,'*,','% '),' ') AS liste_specialite,
NULL::bigint[] AS liste_specialite_pmsi_id ,
NULL::bigint[] AS liste_specialite_activite_id ,
CASE WHEN liste_rubrique <> '' THEN '1' ELSE '0' END AS a_liste_rubrique,
string_to_array(translate(liste_rubrique,'*,','% '),' ') AS liste_rubrique,
NULL::bigint[] AS liste_rubrique_id,
CASE WHEN liste_prestation <> '' THEN '1' ELSE '0' END AS a_liste_prestation,
string_to_array(translate(liste_prestation,'*,','% '),' ') AS liste_prestation,
NULL::bigint[] AS liste_prestation_id
FROM activite.t_pole_rule
JOIN activite.t_pole ON pole_id = t_pole.oid
ORDER BY priorite, pole_id;
UPDATE w_pole_rule
SET liste_finess_id = (SELECT base.cti_group_array3(oid) FROM base.t_finess WHERE code LIKE ANY (liste_finess))
WHERE a_liste_finess = '1';
IF _module_pmsimco = '1' THEN
UPDATE w_pole_rule
SET liste_diagnostic_principal_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_diagnostics WHERE code LIKE ANY (liste_diagnostic_principal))
WHERE a_liste_diagnostic_principal = '1';
UPDATE w_pole_rule
SET liste_diagnostic_relie_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_diagnostics WHERE code LIKE ANY (liste_diagnostic_relie))
WHERE a_liste_diagnostic_relie = '1';
UPDATE w_pole_rule
SET liste_diagnostic_associe_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_diagnostics WHERE code LIKE ANY (liste_diagnostic_associe))
WHERE a_liste_diagnostic_associe = '1';
UPDATE w_pole_rule
SET liste_acte_pmsi_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_actes WHERE code LIKE ANY (liste_acte))
WHERE a_liste_acte = '1';
DROP TABLE IF EXISTS w_pole_rule_actes_pmsi;
CREATE TEMP TABLE w_pole_rule_actes_pmsi AS
SELECT t_actes.oid AS rule_acte_id, w_pole_rule.oid AS rule_id
FROM pmsi.t_actes
JOIN w_pole_rule ON code LIKE ANY (liste_acte);
CREATE INDEX w_pole_rule_actes_pmsi_i1 ON w_pole_rule_actes_pmsi USING btree (rule_acte_id);
END IF;
DROP TABLE IF EXISTS w_pole_rule_actes_base;
CREATE TEMP TABLE w_pole_rule_actes_base AS
SELECT t_actes.oid AS rule_acte_id, w_pole_rule.oid AS rule_id
FROM base.t_actes
JOIN w_pole_rule ON code LIKE ANY (liste_acte);
CREATE INDEX w_pole_rule_actes_base_i1 ON w_pole_rule_actes_base USING btree (rule_acte_id);
DROP TABLE IF EXISTS w_pole_rule_rubriques;
CREATE TEMP TABLE w_pole_rule_rubriques AS
SELECT t_rubriques_facturation.oid AS rule_rubrique_id, w_pole_rule.oid AS rule_id
FROM activite.t_rubriques_facturation
JOIN w_pole_rule ON code LIKE ANY (liste_rubrique);
CREATE INDEX w_pole_rule_rubriques_i1 ON w_pole_rule_rubriques USING btree (rule_rubrique_id);
DROP TABLE IF EXISTS w_pole_rule_prestations;
CREATE TEMP TABLE w_pole_rule_prestations AS
SELECT t_prestations.oid AS rule_prestation_id, w_pole_rule.oid AS rule_id
FROM activite.t_prestations
JOIN w_pole_rule ON code LIKE ANY (liste_prestation);
CREATE INDEX w_pole_rule_prestations_i1 ON w_pole_rule_prestations USING btree (rule_prestation_id);
UPDATE w_pole_rule
SET liste_acte_base_id = (SELECT base.cti_group_array3(oid) FROM base.t_actes WHERE code LIKE ANY (liste_acte))
WHERE a_liste_acte = '1'
;
UPDATE w_pole_rule
SET liste_acte_base_id =
array_cat(liste_acte_base_id,
(SELECT base.cti_group_array3(t_actes.oid)
FROM base.t_actes
JOIN activite.t_listes_contenu ON to_id = t_actes.oid
JOIN activite.t_listes ON t_listes_contenu.liste_id = t_listes.oid
WHERE '[LISTE:'||t_listes.code||']' LIKE ANY (liste_acte))
)
WHERE a_liste_acte = '1' AND
array_to_string(liste_acte,' ') LIKE '%[LISTE:%'
;
IF _module_pmsimco = '1' THEN
UPDATE w_pole_rule
SET liste_ghm_pmsi_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_ghm WHERE code LIKE ANY (liste_ghm))
WHERE a_liste_ghm = '1';
UPDATE w_pole_rule
SET liste_ghm_pmsi_id =
array_cat(liste_ghm_pmsi_id,
(SELECT base.cti_group_array3(t_ghm.oid) FROM pmsi.t_ghm JOIN base.t_cas ON cas_id = t_cas.oid WHERE '[CAS:'||t_cas.code||']' LIKE ANY (liste_ghm))
)
WHERE a_liste_ghm = '1' AND
liste_ghm_origine LIKE '%[CAS:%'
;
END IF;
UPDATE w_pole_rule
SET liste_ghm_activite_id = (SELECT base.cti_group_array3(oid) FROM base.t_ghm WHERE code LIKE ANY (liste_ghm))
WHERE a_liste_ghm = '1'
;
UPDATE w_pole_rule
SET liste_ghm_activite_id =
array_cat(liste_ghm_activite_id,
(SELECT base.cti_group_array3(t_ghm.oid) FROM base.t_ghm JOIN base.t_cas ON cas_id = t_cas.oid WHERE '[CAS:'||t_cas.code||']' LIKE ANY (liste_ghm))
)
WHERE a_liste_ghm = '1' AND
liste_ghm_origine LIKE '%[CAS:%'
;
UPDATE w_pole_rule
SET liste_acte_base_id =
array_cat(liste_acte_base_id,
(SELECT base.cti_group_array3(t_actes.oid)
FROM base.t_actes
JOIN activite.t_listes_contenu ON to_id = t_actes.oid
JOIN activite.t_listes ON t_listes_contenu.liste_id = t_listes.oid
WHERE '[LISTE:'||t_listes.code||']' LIKE ANY (liste_acte))
)
WHERE a_liste_acte = '1' AND
array_to_string(liste_acte,' ') LIKE '%[LISTE:%'
;
IF _module_pmsimco = '1' THEN
UPDATE w_pole_rule
SET liste_sauf_ghm_pmsi_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_ghm WHERE code LIKE ANY (liste_sauf_ghm))
WHERE a_liste_sauf_ghm = '1';
END IF;
UPDATE w_pole_rule
SET liste_sauf_ghm_activite_id = (SELECT base.cti_group_array3(oid) FROM base.t_ghm WHERE code LIKE ANY (liste_sauf_ghm))
WHERE a_liste_sauf_ghm = '1'
;
UPDATE w_pole_rule
SET liste_sauf_ghm_activite_id =
array_cat(liste_sauf_ghm_activite_id,
(SELECT base.cti_group_array3(t_ghm.oid)
FROM base.t_ghm
JOIN activite.t_listes_contenu ON to_id = t_ghm.oid
JOIN activite.t_listes ON t_listes_contenu.liste_id = t_listes.oid
WHERE '[LISTE:'||t_listes.code||']' LIKE ANY (liste_sauf_ghm))
)
WHERE a_liste_sauf_ghm = '1' AND
liste_sauf_ghm_origine LIKE '%[LISTE:%'
;
IF _module_pmsimco = '1' THEN
UPDATE w_pole_rule
SET liste_medecin_pmsi_id = (
SELECT base.cti_group_array3(t_medecins_pmsi.oid)
FROM pmsi.t_medecins t_medecins_pmsi
JOIN base.t_medecins ON t_medecins_pmsi.medecin_reference_id = t_medecins.oid
WHERE t_medecins_pmsi.oid <> 0 AND t_medecins_pmsi.code <> '' AND t_medecins_pmsi.code LIKE ANY (liste_medecin) AND liste_medecin[1] <> '(R)' OR
t_medecins.oid <> 0 AND t_medecins.code <> '' AND t_medecins.code LIKE ANY (liste_medecin) AND liste_medecin[1] = '(R)'
)
WHERE a_liste_medecin = '1';
END IF;
UPDATE w_pole_rule
SET liste_medecin_activite_id = (
SELECT base.cti_group_array3(t_medecins_administratifs.oid)
FROM activite.t_medecins_administratifs
JOIN base.t_medecins ON t_medecins_administratifs.medecin_id = t_medecins.oid
WHERE t_medecins_administratifs.oid <> 0 AND t_medecins_administratifs.code <> '' AND t_medecins_administratifs.code LIKE ANY (liste_medecin) AND liste_medecin[1] <> '(R)' OR
t_medecins.oid <> 0 AND t_medecins.code <> '' AND t_medecins.code LIKE ANY (liste_medecin) AND liste_medecin[1] = '(R)'
)
WHERE a_liste_medecin = '1'
;
IF _module_pmsimco = '1' THEN
UPDATE w_pole_rule
SET liste_specialite_pmsi_id = (SELECT base.cti_group_array3(oid) FROM pmsi.t_specialites_medecin WHERE oid <> 0 AND code LIKE ANY (liste_specialite))
WHERE a_liste_specialite = '1';
END IF;
UPDATE w_pole_rule
SET liste_specialite_activite_id = (SELECT base.cti_group_array3(oid) FROM base.t_specialites_medecin WHERE oid <> 0 AND code LIKE ANY (liste_specialite))
WHERE a_liste_specialite = '1'
;
UPDATE w_pole_rule
SET liste_type_sejour_id = (SELECT base.cti_group_array3(code) FROM activite.t_type_sejour WHERE oid <> 0 AND code <> '' AND code LIKE ANY (liste_type_sejour))
WHERE a_liste_type_sejour = '1'
;
UPDATE w_pole_rule
SET liste_unite_fonctionnelle_id = (SELECT base.cti_group_array3(oid) FROM activite.t_unites_fonctionnelles WHERE oid <> 0 AND code LIKE ANY (liste_unite_fonctionnelle))
WHERE a_liste_unite_fonctionnelle = '1'
;
UPDATE w_pole_rule
SET liste_service_id = (SELECT base.cti_group_array3(oid) FROM activite.t_services_facturation WHERE oid <> 0 AND code LIKE ANY (liste_service))
WHERE a_liste_service = '1'
;
UPDATE w_pole_rule
SET liste_etage_id = (SELECT base.cti_group_array3(oid) FROM activite.t_etages WHERE oid <> 0 AND code LIKE ANY (liste_etage))
WHERE a_liste_etage = '1'
;
UPDATE w_pole_rule
SET liste_activite_id = (SELECT base.cti_group_array3(oid) FROM activite.t_activites WHERE oid <> 0 AND code LIKE ANY (liste_activite))
WHERE a_liste_activite = '1'
;
UPDATE w_pole_rule
SET liste_rubrique_id = (SELECT base.cti_group_array3(oid) FROM activite.t_rubriques_facturation WHERE oid <> 0 AND code LIKE ANY (liste_rubrique))
WHERE a_liste_rubrique = '1'
;
UPDATE w_pole_rule
SET liste_prestation_id = (SELECT base.cti_group_array3(oid) FROM activite.t_prestations WHERE oid <> 0 AND code LIKE ANY (liste_prestation))
WHERE a_liste_prestation = '1'
;
-- Association cles aux rubriques
RAISE NOTICE '%' , 'Application des regles. Traitement des rubriques';
DROP TABLE IF EXISTS w_factures_rubriques;
IF _with_rubrique = '1' THEN
CREATE TEMP TABLE w_factures_rubriques AS
SELECT
p_factures.no_sejour, rule_id
FROM activite.p_factures_lignes_c
JOIN activite.p_factures ON p_factures.no_facture = p_factures_lignes_c.no_facture
JOIN w_pole_rule_rubriques ON p_factures_lignes_c.prestation_id = rule_rubrique_id
WHERE p_factures_lignes_c.montant_facture <> 0
GROUP BY 1,2
HAVING SUM(p_factures_lignes_c.montant_facture) > 0
UNION
SELECT
p_factures.no_sejour, rule_id
FROM activite.p_factures_lignes_non_facturees_c
JOIN activite.p_factures ON p_factures.no_facture = p_factures_lignes_non_facturees_c.no_facture
JOIN w_pole_rule_rubriques ON p_factures_lignes_non_facturees_c.prestation_id = rule_rubrique_id
;
CREATE INDEX w_factures_rubriques_i1 ON w_factures_rubriques USING btree (no_sejour);
ELSE
CREATE TEMP TABLE w_factures_rubriques (no_sejour text, rule_id bigint);
END IF;
DROP TABLE IF EXISTS w_pole_rubriques;
CREATE TEMP TABLE w_pole_rubriques AS
SELECT oid, base.cti_group_array3(rubrique_rule_id) AS rubrique_liste_rule_id
FROM
(
SELECT
w_sejours_rss.oid, rule_id AS rubrique_rule_id
FROM w_factures_rubriques
JOIN w_sejours_rss ON w_factures_rubriques.no_sejour = w_sejours_rss.no_sejour
) subview
GROUP BY 1;
ALTER TABLE w_pole_rubriques ADD CONSTRAINT w_pole_rubriques_pkey PRIMARY KEY(oid);
UPDATE w_sejours_rss
SET rubrique_liste_rule_id = w_pole_rubriques.rubrique_liste_rule_id
FROM w_pole_rubriques
WHERE w_pole_rubriques.oid = w_sejours_rss.oid;
-- Association cles aux prestations
RAISE NOTICE '%' , 'Application des regles. Traitement des prestations';
DROP TABLE IF EXISTS w_factures_prestations;
IF _with_prestation = '1' THEN
CREATE TEMP TABLE w_factures_prestations AS
SELECT
p_factures.no_sejour, rule_id
FROM activite.p_factures_lignes_c
JOIN activite.p_factures ON p_factures.no_facture = p_factures_lignes_c.no_facture
JOIN w_pole_rule_prestations ON p_factures_lignes_c.prestation_id = rule_prestation_id
WHERE p_factures_lignes_c.montant_facture <> 0
GROUP BY 1,2
HAVING SUM(p_factures_lignes_c.montant_facture) > 0
UNION
SELECT
p_factures.no_sejour, rule_id
FROM activite.p_factures_lignes_non_facturees_c
JOIN activite.p_factures ON p_factures.no_facture = p_factures_lignes_non_facturees_c.no_facture
JOIN w_pole_rule_prestations ON p_factures_lignes_non_facturees_c.prestation_id = rule_prestation_id
GROUP BY 1,2
;
ELSE
CREATE TEMP TABLE w_factures_prestations (no_sejour text, rule_id bigint);
END IF;
CREATE INDEX w_factures_prestations_i1 ON w_factures_prestations USING btree (no_sejour);
DROP TABLE IF EXISTS w_pole_prestations;
CREATE TEMP TABLE w_pole_prestations AS
SELECT oid, base.cti_group_array3(prestation_rule_id) AS prestation_liste_rule_id
FROM
(
SELECT
w_sejours_rss.oid, rule_id AS prestation_rule_id
FROM w_factures_prestations
JOIN w_sejours_rss ON w_factures_prestations.no_sejour = w_sejours_rss.no_sejour
) subview
GROUP BY 1;
ALTER TABLE w_pole_prestations ADD CONSTRAINT w_pole_prestations_pkey PRIMARY KEY(oid);
UPDATE w_sejours_rss
SET prestation_liste_rule_id = w_pole_prestations.prestation_liste_rule_id
FROM w_pole_prestations
WHERE w_pole_prestations.oid = w_sejours_rss.oid;
-- Association cles aux actes
RAISE NOTICE '%' , 'Application des regles. Traitement des actes';
DROP TABLE IF EXISTS w_factures_actes;
IF _with_acte = '1' THEN
CREATE TEMP TABLE w_factures_actes AS
SELECT
no_facture, rule_id
FROM activite.p_factures_lignes_h
JOIN w_pole_rule_actes_base ON p_factures_lignes_h.acte_id = rule_acte_id
WHERE activite_ccam <> '4'
UNION
SELECT
no_facture, rule_id
FROM activite.p_factures_lignes_non_facturees_h
JOIN w_pole_rule_actes_base ON p_factures_lignes_non_facturees_h.acte_id = rule_acte_id
WHERE activite_ccam <> '4';
ELSE
CREATE TEMP TABLE w_factures_actes (no_facture text, rule_id bigint);
END IF;
CREATE INDEX w_factures_actes_i1 ON w_factures_actes USING btree (no_facture);
DROP TABLE IF EXISTS w_pole_actes;
IF _module_pmsimco = '1' THEN
CREATE TEMP TABLE w_pole_actes AS
SELECT oid, base.cti_group_array3(acte_rule_id) AS acte_liste_rule_id
FROM
(
SELECT
w_sejours_rss.oid, rule_id AS acte_rule_id
FROM pmsi.p_rss_actes
JOIN w_sejours_rss ON p_rss_actes.rss_id = w_sejours_rss.rss_id
JOIN w_pole_rule_actes_pmsi ON p_rss_actes.acte_id = rule_acte_id
UNION
SELECT
w_sejours_rss.oid, rule_id AS acte_rule_id
FROM w_factures_actes
JOIN activite.p_factures ON w_factures_actes.no_facture = p_factures.no_facture
JOIN w_sejours_rss ON p_factures.no_sejour = w_sejours_rss.no_sejour
) subview
GROUP BY 1;
ELSE
CREATE TEMP TABLE w_pole_actes AS
SELECT oid, base.cti_group_array3(acte_rule_id) AS acte_liste_rule_id
FROM
(
SELECT
w_sejours_rss.oid, rule_id AS acte_rule_id
FROM w_factures_actes
JOIN activite.p_factures ON w_factures_actes.no_facture = p_factures.no_facture
JOIN w_sejours_rss ON p_factures.no_sejour = w_sejours_rss.no_sejour
) subview
GROUP BY 1;
END IF;
ALTER TABLE w_pole_actes ADD CONSTRAINT w_pole_actes_pkey PRIMARY KEY(oid);
UPDATE w_sejours_rss
SET acte_liste_rule_id = w_pole_actes.acte_liste_rule_id
FROM w_pole_actes
WHERE w_pole_actes.oid = w_sejours_rss.oid;
-- Diagnostics
IF _module_pmsimco = '1' THEN
RAISE NOTICE '%' , 'Application des regles. Traitement des diagnostics';
DROP TABLE IF EXISTS w_pole_diagnostics;
CREATE TEMP TABLE w_pole_diagnostics AS
SELECT
w_sejours_rss.oid, base.cti_group_array3(w_pole_rule.oid) AS diagnostic_associe_liste_rule_id
FROM pmsi.p_rss_diagnostics
JOIN w_pole_rule ON type_diagnostic_rss IN ('DA', 'DS') AND diagnostic_id = ANY (liste_diagnostic_associe_id)
JOIN w_sejours_rss ON p_rss_diagnostics.rss_id = w_sejours_rss.rss_id
WHERE a_liste_diagnostic_associe <> '0'
GROUP BY 1;
ALTER TABLE w_pole_diagnostics ADD CONSTRAINT w_pole_diagnostics_pkey PRIMARY KEY(oid);
UPDATE w_sejours_rss
SET diagnostic_associe_liste_rule_id = w_pole_diagnostics.diagnostic_associe_liste_rule_id
FROM w_pole_diagnostics
WHERE w_pole_diagnostics.oid = w_sejours_rss.oid;
END IF;
-- Mise à jour des cles venant des données du PMSI
RAISE NOTICE '%' , 'Application des regles. Attribution des poles venant du pmsi';
DROP TABLE IF EXISTS w_sejours_pole;
CREATE TEMP TABLE w_sejours_pole AS
SELECT w_sejours_rss.oid,
MIN(priorite)+1 AS pole_priorite,
(MIN(ARRAY[priorite,w_pole_rule.pole_id]))[2] AS pole_id
FROM w_sejours_rss
JOIN w_pole_rule ON
(a_liste_finess = '0' OR finess_id = ANY (liste_finess_id)) AND
(a_liste_medecin = '0' OR medecin_rss_id = ANY (liste_medecin_pmsi_id)) AND
(a_liste_type_sejour = '0') AND
(a_liste_unite_fonctionnelle = '0') AND
(a_liste_service = '0') AND
(a_liste_etage = '0') AND
(a_liste_activite = '0') AND
(a_liste_specialite = '0' OR specialite_rss_id = ANY (liste_specialite_pmsi_id)) AND
(a_liste_diagnostic_principal = '0' OR diagnostic_principal_id = ANY (liste_diagnostic_principal_id)) AND
(a_liste_diagnostic_relie = '0' OR diagnostic_relie_id = ANY (liste_diagnostic_relie_id)) AND
(a_liste_diagnostic_associe = '0' OR w_pole_rule.oid = ANY(diagnostic_associe_liste_rule_id)) AND
(a_liste_acte = '0' OR w_pole_rule.oid = ANY(acte_liste_rule_id)) AND
(a_liste_ghm = '0' OR ghm_pmsi_id = ANY (liste_ghm_pmsi_id)) AND
(a_liste_sauf_ghm = '0' OR ghm_pmsi_id <> ALL (liste_sauf_ghm_pmsi_id)) AND
(a_liste_prestation = '0') AND
(a_liste_rubrique = '0')
WHERE w_sejours_rss.rss_id <> 0
GROUP BY 1
ORDER BY 1;
UPDATE w_sejours_rss SET
pole_id = w_sejours_pole.pole_id,
pole_priorite = w_sejours_pole.pole_priorite
FROM w_sejours_pole
WHERE w_sejours_rss.oid = w_sejours_pole.oid;
-- Mise à jour des cles venant des données d'activite
RAISE NOTICE '%' , 'Application des regles. Attribution des poles venant de la GAP';
DROP TABLE IF EXISTS w_sejours_pole;
CREATE TEMP TABLE w_sejours_pole AS
SELECT w_sejours_rss.oid,
MIN(priorite) AS pole_priorite,
(MIN(ARRAY[priorite,w_pole_rule.pole_id]))[2] AS pole_id
FROM w_sejours_rss
JOIN w_pole_rule ON
(a_liste_finess = '0' OR finess_id = ANY (liste_finess_id)) AND
(a_liste_type_sejour = '0' OR type_sejour = ANY (liste_type_sejour_id)) AND
(a_liste_unite_fonctionnelle = '0' OR unite_fonctionnelle_id = ANY (liste_unite_fonctionnelle_id)) AND
(a_liste_service = '0' OR service_facturation_id = ANY (liste_service_id)) AND
(a_liste_etage = '0' OR etage_id = ANY (liste_etage_id)) AND
(a_liste_activite = '0' OR activite_id = ANY (liste_activite_id)) AND
(a_liste_medecin = '0' OR medecin_sejour_id = ANY (liste_medecin_activite_id)) AND
(a_liste_specialite = '0' OR specialite_sejour_id = ANY (liste_specialite_activite_id)) AND
(a_liste_diagnostic_principal = '0' OR diagnostic_principal_id = ANY (liste_diagnostic_principal_id)) AND
(a_liste_diagnostic_relie = '0' OR diagnostic_relie_id = ANY (liste_diagnostic_relie_id)) AND
(a_liste_diagnostic_associe = '0' OR w_pole_rule.oid = ANY(diagnostic_associe_liste_rule_id)) AND
(a_liste_acte = '0' OR w_pole_rule.oid = ANY(acte_liste_rule_id)) AND
(a_liste_rubrique = '0' OR w_pole_rule.oid = ANY(rubrique_liste_rule_id)) AND
(a_liste_prestation = '0' OR w_pole_rule.oid = ANY(prestation_liste_rule_id)) AND
(a_liste_ghm = '0' OR ghm_activite_id = ANY (liste_ghm_activite_id)) AND
(a_liste_sauf_ghm = '0' OR ghm_activite_id <> ALL (liste_sauf_ghm_activite_id))
WHERE w_sejours_rss.sejour_id <> 0
GROUP BY 1
ORDER BY 1;
UPDATE w_sejours_rss SET
pole_id = w_sejours_pole.pole_id,
pole_priorite = w_sejours_pole.pole_priorite
FROM w_sejours_pole
WHERE w_sejours_rss.oid = w_sejours_pole.oid AND
(w_sejours_rss.pole_priorite > w_sejours_pole.pole_priorite OR w_sejours_rss.pole_priorite = 0);
RAISE NOTICE '%' , 'Application des regles. Validation des poles';
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_sejour_lieu';
TRUNCATE activite.p_sejour_lieu;
INSERT INTO activite.p_sejour_lieu (no_sejour, sejour_id, lieu_id, pole_id)
SELECT no_sejour, sejour_id, lieu_id, MAX(pole_id) AS pole_id
FROM w_sejours_rss
GROUP BY 1,2,3
;
ANALYSE activite.p_sejour_lieu
;
-- Réplication dans tables de prod
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_mouvements_sejour';
DROP TABLE IF EXISTS w_mouvement_pole;
CREATE TEMP TABLE w_mouvement_pole AS
SELECT p_mouvements_sejour.*, COALESCE(p_sejour_lieu.pole_id,0) AS new_pole_id
FROM activite.p_mouvements_sejour
LEFT JOIN activite.p_sejour_lieu ON
p_mouvements_sejour.no_sejour = p_sejour_lieu.no_sejour AND
p_mouvements_sejour.lieu_id = p_sejour_lieu.lieu_id
;
UPDATE w_mouvement_pole
SET pole_id = new_pole_id
WHERE pole_id IS DISTINCT FROM new_pole_id
;
ALTER TABLE w_mouvement_pole DROP COLUMN new_pole_id
;
TRUNCATE activite.p_mouvements_sejour
;
INSERT INTO activite.p_mouvements_sejour SELECT * FROM w_mouvement_pole
;
ANALYSE activite.p_mouvements_sejour
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_factures_lignes_c';
DROP TABLE IF EXISTS w_ligne_pole_c;
CREATE TEMP TABLE w_ligne_pole_c AS
SELECT p_factures_lignes_c.*, COALESCE(p_sejour_lieu.pole_id,0) AS new_pole_id
FROM activite.p_factures_lignes_c
JOIN activite.p_factures ON p_factures_lignes_c.no_facture = p_factures.no_facture
LEFT JOIN activite.p_sejour_lieu ON
p_factures.no_sejour = p_sejour_lieu.no_sejour AND
p_factures_lignes_c.lieu_id = p_sejour_lieu.lieu_id
;
UPDATE w_ligne_pole_c
SET pole_id = new_pole_id
WHERE pole_id IS DISTINCT FROM new_pole_id
;
ALTER TABLE w_ligne_pole_c DROP COLUMN new_pole_id
;
TRUNCATE activite.p_factures_lignes_c
;
INSERT INTO activite.p_factures_lignes_c SELECT * FROM w_ligne_pole_c
;
ANALYSE activite.p_factures_lignes_c
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_factures_encours_lignes_c';
DROP TABLE IF EXISTS w_encours_ligne_pole_c;
CREATE TEMP TABLE w_encours_ligne_pole_c AS
SELECT p_factures_encours_lignes_c.*, COALESCE(p_sejour_lieu.pole_id,0) AS new_pole_id
FROM activite.p_factures_encours_lignes_c
JOIN activite.p_factures_encours ON p_factures_encours_lignes_c.no_facture = p_factures_encours.no_facture
LEFT JOIN activite.p_sejour_lieu ON
p_factures_encours.no_sejour = p_sejour_lieu.no_sejour AND
p_factures_encours_lignes_c.lieu_id = p_sejour_lieu.lieu_id
;
UPDATE w_encours_ligne_pole_c
SET pole_id = new_pole_id
WHERE pole_id IS DISTINCT FROM new_pole_id
;
ALTER TABLE w_encours_ligne_pole_c DROP COLUMN new_pole_id
;
TRUNCATE activite.p_factures_encours_lignes_c
;
INSERT INTO activite.p_factures_encours_lignes_c SELECT * FROM w_encours_ligne_pole_c
;
ANALYSE activite.p_factures_encours_lignes_c
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_factures_lignes_h';
DROP TABLE IF EXISTS w_ligne_pole_h;
CREATE TEMP TABLE w_ligne_pole_h AS
SELECT p_factures_lignes_h.*, COALESCE(p_sejour_lieu.pole_id,0) AS new_pole_id
FROM activite.p_factures_lignes_h
JOIN activite.p_factures ON p_factures_lignes_h.no_facture = p_factures.no_facture
LEFT JOIN activite.p_sejour_lieu ON
p_factures.no_sejour = p_sejour_lieu.no_sejour AND
p_factures_lignes_h.lieu_id = p_sejour_lieu.lieu_id
;
UPDATE w_ligne_pole_h
SET pole_id = new_pole_id
WHERE pole_id IS DISTINCT FROM new_pole_id
;
ALTER TABLE w_ligne_pole_h DROP COLUMN new_pole_id
;
TRUNCATE activite.p_factures_lignes_h
;
INSERT INTO activite.p_factures_lignes_h SELECT * FROM w_ligne_pole_h
;
ANALYSE activite.p_factures_lignes_h
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_factures_reference';
DROP TABLE IF EXISTS w_facture_pole;
CREATE TEMP TABLE w_facture_pole AS
SELECT no_facture_reference,
(MAX(ARRAY[p_mouvements_sejour.date::text, to_char(p_mouvements_sejour.heure_debut,'FM000000'), p_mouvements_sejour.pole_id::text]))[3]::bigint AS pole_sortie_id
FROM activite.p_factures_reference
JOIN activite.p_mouvements_sejour ON
p_mouvements_sejour.no_sejour = p_factures_reference.no_sejour AND
p_mouvements_sejour.date BETWEEN p_factures_reference.date_debut_facture AND date_fin_facture
GROUP BY 1
;
UPDATE activite.p_factures_reference
SET pole_sortie_id = w_facture_pole.pole_sortie_id
FROM w_facture_pole
WHERE p_factures_reference.no_facture_reference = w_facture_pole.no_facture_reference AND
p_factures_reference.pole_sortie_id IS DISTINCT FROM w_facture_pole.pole_sortie_id
;
ANALYSE activite.p_factures_reference
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. p_factures_reference';
UPDATE activite.p_factures_reference_tiers
SET pole_sortie_id = w_facture_pole.pole_sortie_id
FROM w_facture_pole
WHERE p_factures_reference_tiers.no_facture_reference = w_facture_pole.no_facture_reference AND
p_factures_reference_tiers.pole_sortie_id IS DISTINCT FROM w_facture_pole.pole_sortie_id
;
ANALYSE activite.p_factures_reference_tiers
;
-- Pole par defaut pour taux d'occupation
RAISE NOTICE '%' , 'Application des regles. Validation des poles. t_etages_historique';
UPDATE activite.t_etages_historique
SET pole_occupation_id = subview.pole_occupation_id
FROM
(
SELECT etage_id, date_debut, (MAX(ARRAY[nb, pole_id]))[2] AS pole_occupation_id
FROM
(
SELECT t_lieux_c.etage_id, t_etages_historique.date AS date_debut, t_etages_historique.date_fin, p_mouvements_sejour.pole_id, count(*) AS nb
FROM activite.p_mouvements_sejour
JOIN activite.t_lieux_c ON p_mouvements_sejour.lieu_id = t_lieux_c.oid
JOIN activite.t_etages_historique ON t_lieux_c.etage_id = t_etages_historique.etage_id AND p_mouvements_sejour.date BETWEEN t_etages_historique.date AND t_etages_historique.date_fin
WHERE t_lieux_c.etage_id <> 0
GROUP BY 1,2,3,4
ORDER BY 1,2
) subview
GROUP BY 1,2
) subview
WHERE t_etages_historique.etage_id = subview.etage_id AND
t_etages_historique.date = subview.date_debut AND
t_etages_historique.pole_occupation_id IS DISTINCT FROM subview.pole_occupation_id
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. t_services_facturation_historique';
UPDATE activite.t_services_facturation_historique
SET pole_occupation_id = subview.pole_occupation_id
FROM
(
SELECT service_facturation_id, date_debut, (MAX(ARRAY[nb, pole_id]))[2] AS pole_occupation_id
FROM
(
SELECT t_lieux_c.service_facturation_id, t_services_facturation_historique.date AS date_debut, t_services_facturation_historique.date_fin, p_mouvements_sejour.pole_id, count(*) AS nb
FROM activite.p_mouvements_sejour
JOIN activite.t_lieux_c ON p_mouvements_sejour.lieu_id = t_lieux_c.oid
JOIN activite.t_services_facturation_historique ON t_lieux_c.service_facturation_id = t_services_facturation_historique.service_facturation_id AND p_mouvements_sejour.date BETWEEN t_services_facturation_historique.date AND t_services_facturation_historique.date_fin
WHERE t_lieux_c.service_facturation_id <> 0
GROUP BY 1,2,3,4
ORDER BY 1,2
) subview
GROUP BY 1,2
) subview
WHERE t_services_facturation_historique.service_facturation_id = subview.service_facturation_id AND
t_services_facturation_historique.date = subview.date_debut AND
t_services_facturation_historique.pole_occupation_id IS DISTINCT FROM subview.pole_occupation_id
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. t_unites_fonctionnelles_historique';
UPDATE activite.t_unites_fonctionnelles_historique
SET pole_occupation_id = subview.pole_occupation_id
FROM
(
SELECT unite_fonctionnelle_id, date_debut, (MAX(ARRAY[nb, pole_id]))[2] AS pole_occupation_id
FROM
(
SELECT t_lieux_c.unite_fonctionnelle_id, t_unites_fonctionnelles_historique.date AS date_debut, t_unites_fonctionnelles_historique.date_fin, p_mouvements_sejour.pole_id, count(*) AS nb
FROM activite.p_mouvements_sejour
JOIN activite.t_lieux_c ON p_mouvements_sejour.lieu_id = t_lieux_c.oid
JOIN activite.t_unites_fonctionnelles_historique ON t_lieux_c.unite_fonctionnelle_id = t_unites_fonctionnelles_historique.unite_fonctionnelle_id AND p_mouvements_sejour.date BETWEEN t_unites_fonctionnelles_historique.date AND t_unites_fonctionnelles_historique.date_fin
WHERE t_lieux_c.unite_fonctionnelle_id <> 0
GROUP BY 1,2,3,4
ORDER BY 1,2
) subview
GROUP BY 1,2
) subview
WHERE t_unites_fonctionnelles_historique.unite_fonctionnelle_id = subview.unite_fonctionnelle_id AND
t_unites_fonctionnelles_historique.date = subview.date_debut AND
t_unites_fonctionnelles_historique.pole_occupation_id IS DISTINCT FROM subview.pole_occupation_id
;
RAISE NOTICE '%' , 'Application des regles. Validation des poles. t_places';
UPDATE activite.t_places
SET pole_id = pole_occupation_id
FROM activite.t_places_parents
JOIN activite.t_etages_historique ON t_places_parents.oid = t_etages_historique.etage_id
WHERE t_places.parent_id = t_places_parents.oid AND
parent_type = 'ETA' AND
t_places.date BETWEEN t_etages_historique.date AND t_etages_historique.date_fin
;
ANALYSE activite.t_places
;
--
INSERT INTO activite.p_oids (code_table, oid)
SELECT 'pole', pole_id
FROM activite.p_sejour_lieu
WHERE pole_id NOT IN (SELECT oid FROM activite.p_oids WHERE code_table = 'pole')
GROUP BY 2;
-- Replication Pole dans PMSI MCO
IF EXISTS (SELECT * FROM pg_tables WHERE schemaname = 'pmsi' AND tablename = 'p_rss_rum') THEN
TRUNCATE pmsi.t_pole;
INSERT INTO pmsi.t_pole (oid, code, texte, texte_court, section_id, section_code, section_texte)
SELECT oid, code, texte, texte_court, section_id, section_code, section_texte
FROM base.t_pole
;
RAISE NOTICE '%' , 'Application des regles PMSI MCO. Validation des poles. p_rss_rum';
DROP TABLE IF EXISTS w_rss_rum_pole;
CREATE TEMP TABLE w_rss_rum_pole AS
SELECT rss_id, no_rum, unite_medicale_id, (MAX(ARRAY[nb, pole_id]))[2] AS pole_id, COUNT(DISTINCT nb) AS nb_nb, count(*) AS nb
FROM
(
SELECT p_rss_rum.rss_id, p_rss_rum.no_rum, unite_medicale_id, p_mouvements_sejour.pole_id, COUNT(DISTINCT(p_mouvements_sejour.date)) AS nb
FROM pmsi.p_rss_rum
JOIN activite.p_sejour_pmsi ON pmsi.p_rss_rum.rss_id = p_sejour_pmsi.rss_id
JOIN activite.p_mouvements_sejour ON
p_mouvements_sejour.sejour_id = p_sejour_pmsi.sejour_id AND
p_mouvements_sejour.date BETWEEN p_rss_rum.date_entree AND p_rss_rum.date_sortie
GROUP BY 1,2,3,4
) subview
GROUP BY 1,2,3
;
UPDATE pmsi.p_rss_rum
SET pole_id = w_rss_rum_pole.pole_id
FROM w_rss_rum_pole
WHERE w_rss_rum_pole.rss_id = p_rss_rum.rss_id AND
w_rss_rum_pole.no_rum = p_rss_rum.no_rum AND
p_rss_rum.pole_id IS DISTINCT FROM w_rss_rum_pole.pole_id AND
nb = nb_nb
;
UPDATE pmsi.p_rss_rum
SET pole_id = 0
WHERE pole_id <> 0 AND
rss_id::text||'-'||no_rum::text NOT IN (SELECT rss_id::text||'-'||no_rum::text FROM w_rss_rum_pole WHERE nb = nb_nb)
;
UPDATE pmsi.p_rss_rum
SET pole_id = subview.pole_id
FROM
(
SELECT unite_medicale_id, (MAX(ARRAY[nb, pole_id]))[2] AS pole_id
FROM
(
SELECT unite_medicale_id, pole_id, count(*) AS nb
FROM w_rss_rum_pole
WHERE pole_id <> 0 AND nb = nb_nb
GROUP BY 1,2
) subview
GROUP BY 1
) subview
WHERE p_rss_rum.pole_id = 0 AND
p_rss_rum.unite_medicale_id = subview.unite_medicale_id
;
ANALYSE pmsi.p_rss_rum
;
RAISE NOTICE '%' , 'Application des regles PMSI MCO. Validation des poles. p_rss_actes';
UPDATE pmsi.p_rss_actes
SET pole_id = p_rss_rum.pole_id
FROM pmsi.p_rss_rum
WHERE p_rss_rum.rss_id = p_rss_actes.rss_id AND
p_rss_rum.no_rum = p_rss_actes.no_rum AND
p_rss_actes.pole_id IS DISTINCT FROM p_rss_rum.pole_id
;
RAISE NOTICE '%' , 'Application des regles PMSI MCO. Validation des poles. p_rss_diagnostics';
UPDATE pmsi.p_rss_diagnostics
SET pole_id = p_rss_rum.pole_id
FROM pmsi.p_rss_rum
WHERE p_rss_rum.rss_id = p_rss_diagnostics.rss_id AND
p_rss_rum.no_rum = p_rss_diagnostics.no_rum AND
p_rss_diagnostics.pole_id IS DISTINCT FROM p_rss_rum.pole_id
;
RAISE NOTICE '%' , 'Application des regles PMSI MCO. Validation des poles. p_rss';
UPDATE pmsi.p_rss
SET pole_id = subview.pole_id
FROM
(
SELECT p_rss_rum.rss_id, MAX(p_rss_rum.pole_id) AS pole_id
FROM pmsi.p_rss_rum
JOIN pmsi.p_rss ON p_rss_rum.rss_id = p_rss.oid AND
p_rss_rum.unite_medicale_id = p_rss.unite_medicale_principale_id
GROUP BY 1
HAVING MAX(p_rss.pole_id) IS DISTINCT FROM MAX(p_rss_rum.pole_id)
) subview
WHERE p_rss.oid = subview.rss_id
;
INSERT INTO pmsi.p_oids (code_table, oid)
SELECT 'pole', pole_id
FROM pmsi.p_rss_rum
WHERE pole_id NOT IN (SELECT oid FROM pmsi.p_oids WHERE code_table = 'pole')
GROUP BY 2;
END IF;
IF EXISTS (SELECT * FROM information_schema.columns WHERE table_schema = 'pmsissr' AND table_name = 'p_ssr' AND column_name = 'pole_id') THEN
UPDATE pmsissr.p_ssr
SET pole_id = subview.pole_id
FROM
(
SELECT p_ssr.oid, (MAX(ARRAY[p_mouvements_sejour.date::text,p_mouvements_sejour.pole_id::text]))[2]::bigint AS pole_id
FROM activite.p_mouvements_sejour
JOIN activite.p_sejour_pmsi ON p_mouvements_sejour.no_sejour = p_sejour_pmsi.no_sejour
JOIN pmsissr.p_ssr ON p_ssr.oid = ANY(ssr_id_array)
GROUP BY 1
) subview
WHERE p_ssr.oid = subview.oid
;
END IF;
RETURN 'OK';
END;