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.
 
 
 

237 lines
14 KiB

src: |
SELECT p_mouvements_articles.provider_id,
p_mouvements_articles.oid AS mouvement_article_id,
p_mouvements_articles.date,
p_mouvements_articles.sens_mouvement,
p_mouvements_articles.type_mouvement_id,
t_types_mouvements.code AS type_mouvement_code,
t_types_mouvements.texte_court AS type_mouvement_texte,
t_types_mouvements.section_id AS type_mouvement_section_id,
t_types_mouvements.section_code AS type_mouvement_section_code,
t_types_mouvements.section_texte AS type_mouvement_section_texte,
p_mouvements_articles.texte,
p_mouvements_articles.site_id,
t_sites.code AS site_code,
t_sites.texte_court AS site_texte,
t_sites.section_id AS site_section_id,
t_sites.section_code AS site_section_code,
t_sites.section_texte AS site_section_texte,
p_mouvements_articles.gestionnaire_id,
t_gestionnaires.code AS gestionnaire_code,
t_gestionnaires.texte_court AS gestionnaire_texte,
t_gestionnaires.section_id AS gestionnaire_section_id,
t_gestionnaires.section_code AS gestionnaire_section_code,
t_gestionnaires.section_texte AS gestionnaire_section_texte,
p_mouvements_articles.lieu_id,
t_lieux.code AS lieu_code,
t_lieux.texte_court AS lieu_texte,
t_lieux.section_id AS lieu_section_id,
t_lieux.section_code AS lieu_section_code,
t_lieux.section_texte AS lieu_section_texte,
p_mouvements_articles.unite_fonctionnelle_id,
t_unites_fonctionnelles.code AS unite_fonctionnelle_code,
t_unites_fonctionnelles.texte AS unite_fonctionnelle_texte,
t_unites_fonctionnelles.section_id AS unite_fonctionnelle_section_id,
t_unites_fonctionnelles.section_code AS unite_fonctionnelle_section_code,
t_unites_fonctionnelles.section_texte AS unite_fonctionnelle_section_texte,
p_mouvements_articles.article_id,
t_articles.code AS article_code,
t_articles.texte AS article_texte,
CASE p_mouvements_articles.fournisseur_id
WHEN 0 THEN
CASE
WHEN t_articles.ref_fournisseur_id[1] IS NOT NULL THEN t_articles.ref_fournisseur_texte[1]::character varying
ELSE t_articles.texte
END
WHEN t_articles.ref_fournisseur_id[1] THEN t_articles.ref_fournisseur_texte[1]::character varying
WHEN t_articles.ref_fournisseur_id[2] THEN t_articles.ref_fournisseur_texte[2]::character varying
WHEN t_articles.ref_fournisseur_id[3] THEN t_articles.ref_fournisseur_texte[3]::character varying
WHEN t_articles.ref_fournisseur_id[4] THEN t_articles.ref_fournisseur_texte[4]::character varying
WHEN t_articles.ref_fournisseur_id[5] THEN t_articles.ref_fournisseur_texte[5]::character varying
WHEN t_articles.ref_fournisseur_id[6] THEN t_articles.ref_fournisseur_texte[6]::character varying
WHEN t_articles.ref_fournisseur_id[7] THEN t_articles.ref_fournisseur_texte[7]::character varying
WHEN t_articles.ref_fournisseur_id[8] THEN t_articles.ref_fournisseur_texte[8]::character varying
WHEN t_articles.ref_fournisseur_id[9] THEN t_articles.ref_fournisseur_texte[9]::character varying
WHEN t_articles.ref_fournisseur_id[10] THEN t_articles.ref_fournisseur_texte[10]::character varying
WHEN t_articles.ref_fournisseur_id[11] THEN t_articles.ref_fournisseur_texte[11]::character varying
WHEN t_articles.ref_fournisseur_id[12] THEN t_articles.ref_fournisseur_texte[12]::character varying
WHEN t_articles.ref_fournisseur_id[13] THEN t_articles.ref_fournisseur_texte[13]::character varying
WHEN t_articles.ref_fournisseur_id[14] THEN t_articles.ref_fournisseur_texte[14]::character varying
WHEN t_articles.ref_fournisseur_id[15] THEN t_articles.ref_fournisseur_texte[15]::character varying
WHEN t_articles.ref_fournisseur_id[16] THEN t_articles.ref_fournisseur_texte[16]::character varying
WHEN t_articles.ref_fournisseur_id[17] THEN t_articles.ref_fournisseur_texte[17]::character varying
WHEN t_articles.ref_fournisseur_id[18] THEN t_articles.ref_fournisseur_texte[18]::character varying
WHEN t_articles.ref_fournisseur_id[19] THEN t_articles.ref_fournisseur_texte[19]::character varying
WHEN t_articles.ref_fournisseur_id[20] THEN t_articles.ref_fournisseur_texte[20]::character varying
ELSE t_articles.texte
END AS article_texte_fournisseur,
t_articles.section_id AS article_section_id,
t_articles.section_code AS article_section_code,
t_articles.section_texte AS article_section_texte,
p_mouvements_articles.compte_id AS compte_article_id,
t_compte.code AS compte_article_code,
t_compte.texte AS compte_article_texte,
t_compte.section_id AS compte_article_section_id,
t_compte.section_code AS compte_article_section_code,
t_compte.section_texte AS compte_article_section_texte,
t_articles.type_id AS type_article_id,
t_articles.type_code AS type_article_code,
t_articles.type_texte AS type_article_texte,
t_articles.type_section_id AS type_article_section_id,
t_articles.type_section_code AS type_article_section_code,
t_articles.type_section_texte AS type_article_section_texte,
t_articles.article_reference_cacic_id,
t_articles.article_reference_cacic_code,
t_articles.article_reference_cacic_texte,
t_articles.article_reference_cacic_section_id,
t_articles.article_reference_cacic_section_code,
t_articles.article_reference_cacic_section_texte,
t_articles.article_reference_cti_id,
t_articles.article_reference_cti_code,
t_articles.article_reference_cti_texte,
t_articles.article_reference_cti_section_id,
t_articles.article_reference_cti_section_code,
t_articles.article_reference_cti_section_texte,
t_articles.classification_atc_id,
t_articles.classification_atc_code,
t_articles.classification_atc_texte,
t_articles.classification_atc_1_id,
t_articles.classification_atc_1_code,
t_articles.classification_atc_1_texte,
t_articles.classification_atc_2_id,
t_articles.classification_atc_2_code,
t_articles.classification_atc_2_texte,
t_articles.classification_atc_3_id,
t_articles.classification_atc_3_code,
t_articles.classification_atc_3_texte,
t_articles.classification_atc_4_id,
t_articles.classification_atc_4_code,
t_articles.classification_atc_4_texte,
t_articles.classification_atc_section_id,
t_articles.classification_atc_section_code,
t_articles.classification_atc_section_texte,
t_articles.famille_id AS famille_article_id,
t_articles.famille_code AS famille_article_code,
t_articles.famille_texte AS famille_article_texte,
t_articles.famille_section_id AS famille_article_section_id,
t_articles.famille_section_code AS famille_article_section_code,
t_articles.famille_section_texte AS famille_article_section_texte,
t_articles.sous_famille_id AS sous_famille_article_id,
t_articles.sous_famille_code AS sous_famille_article_code,
t_articles.sous_famille_texte AS sous_famille_article_texte,
t_articles.sous_famille_section_id AS sous_famille_article_section_id,
t_articles.sous_famille_section_code AS sous_famille_article_section_code,
t_articles.sous_famille_section_texte AS sous_famille_article_section_texte,
t_articles.categorie_id AS categorie_article_id,
t_articles.categorie_code AS categorie_article_code,
t_articles.categorie_texte AS categorie_article_texte,
t_articles.categorie_section_id AS categorie_article_section_id,
t_articles.categorie_section_code AS categorie_article_section_code,
t_articles.categorie_section_texte AS categorie_article_section_texte,
t_articles.sous_categorie_id AS sous_categorie_article_id,
t_articles.sous_categorie_code AS sous_categorie_article_code,
t_articles.sous_categorie_texte AS sous_categorie_article_texte,
t_articles.sous_categorie_section_id AS sous_categorie_article_section_id,
t_articles.sous_categorie_section_code AS sous_categorie_article_section_code,
t_articles.sous_categorie_section_texte AS sous_categorie_article_section_texte,
t_articles.unite_stockage_id AS unite_stockage_article_id,
t_articles.unite_stockage_code AS unite_stockage_article_code,
t_articles.unite_stockage_texte AS unite_stockage_article_texte,
t_articles.unite_stockage_section_id AS unite_stockage_article_section_id,
t_articles.unite_stockage_section_code AS unite_stockage_article_section_code,
t_articles.unite_stockage_section_texte AS unite_stockage_article_section_texte,
t_articles.unite_distribution_id AS unite_distribution_article_id,
t_articles.unite_distribution_code AS unite_distribution_article_code,
t_articles.unite_distribution_texte AS unite_distribution_article_texte,
t_articles.unite_distribution_section_id AS unite_distribution_article_section_id,
t_articles.unite_distribution_section_code AS unite_distribution_article_section_code,
t_articles.unite_distribution_section_texte AS unite_distribution_article_section_texte,
p_mouvements_articles.ucd_id AS ucd_mouvement_id,
t_ucd_c.code AS ucd_mouvement_code,
t_ucd_c.texte AS ucd_mouvement_texte,
t_ucd_c.section_id AS ucd_mouvement_section_id,
t_ucd_c.section_code AS ucd_mouvement_section_code,
t_ucd_c.section_texte AS ucd_mouvement_section_texte,
p_mouvements_articles.lpp_id AS lpp_mouvement_id,
t_lpp_c.code AS lpp_mouvement_code,
t_lpp_c.texte AS lpp_mouvement_texte,
t_lpp_c.section_id AS lpp_mouvement_section_id,
t_lpp_c.section_code AS lpp_mouvement_section_code,
t_lpp_c.section_texte AS lpp_mouvement_section_texte,
p_mouvements_articles.ucd_id,
t_ucd_c.code AS ucd_code,
t_ucd_c.texte AS ucd_texte,
t_ucd_c.section_id AS ucd_section_id,
t_ucd_c.section_code AS ucd_section_code,
t_ucd_c.section_texte AS ucd_section_texte,
p_mouvements_articles.lpp_id,
t_lpp_c.code AS lpp_code,
t_lpp_c.texte AS lpp_texte,
t_lpp_c.section_id AS lpp_section_id,
t_lpp_c.section_code AS lpp_section_code,
t_lpp_c.section_texte AS lpp_section_texte,
p_mouvements_articles.fournisseur_id,
t_fournisseurs.code AS fournisseur_code,
t_fournisseurs.texte_court AS fournisseur_texte,
t_fournisseurs.section_id AS fournisseur_section_id,
t_fournisseurs.section_code AS fournisseur_section_code,
t_fournisseurs.section_texte AS fournisseur_section_texte,
t_fournisseurs.type_id AS type_fournisseur_id,
t_fournisseurs.type_code AS type_fournisseur_code,
t_fournisseurs.type_texte AS type_fournisseur_texte,
t_fournisseurs.type_section_id AS type_fournisseur_section_id,
t_fournisseurs.type_section_code AS type_fournisseur_section_code,
t_fournisseurs.type_section_texte AS type_fournisseur_section_texte,
t_fournisseurs.fournisseur_reference_cacic_id,
t_fournisseurs.fournisseur_reference_cacic_code,
t_fournisseurs.fournisseur_reference_cacic_texte,
t_fournisseurs.fournisseur_reference_cacic_section_id,
t_fournisseurs.fournisseur_reference_cacic_section_code,
t_fournisseurs.fournisseur_reference_cacic_section_texte,
t_fournisseurs.fournisseur_reference_cti_id,
t_fournisseurs.fournisseur_reference_cti_code,
t_fournisseurs.fournisseur_reference_cti_texte,
t_fournisseurs.fournisseur_reference_cti_section_id,
t_fournisseurs.fournisseur_reference_cti_section_code,
t_fournisseurs.fournisseur_reference_cti_section_texte,
p_mouvements_articles.prix_unitaire,
p_mouvements_articles.entree_quantite,
p_mouvements_articles.sortie_quantite,
p_mouvements_articles.entree_montant,
p_mouvements_articles.sortie_montant,
p_mouvements_articles.entree_montant AS entree_montant_ttc,
p_mouvements_articles.sortie_montant AS sortie_montant_ttc,
p_mouvements_articles.entree_montant_ht,
p_mouvements_articles.sortie_montant_ht,
p_mouvements_articles.entree_montant - p_mouvements_articles.entree_montant_ht AS entree_montant_tva,
p_mouvements_articles.sortie_montant - p_mouvements_articles.sortie_montant_ht AS entree_sortie_tva,
p_mouvements_articles.sortie_montant_original_ht,
p_mouvements_articles.sortie_montant_original_ttc,
p_mouvements_articles.commande_id,
p_mouvements_articles.ligne_commande,
p_mouvements_articles.stock_quantite_debut,
p_mouvements_articles.stock_quantite_fin,
p_mouvements_articles.pole_id,
CASE
WHEN rank() OVER (PARTITION BY p_mouvements_articles.article_id, p_mouvements_articles.lieu_id ORDER BY p_mouvements_articles.oid) = 1 THEN 1
ELSE 0
END AS est_premier_jour,
CASE
WHEN last_value(p_mouvements_articles.oid) OVER (PARTITION BY p_mouvements_articles.article_id, p_mouvements_articles.lieu_id, p_mouvements_articles.date ORDER BY p_mouvements_articles.oid) = p_mouvements_articles.oid THEN 1
ELSE 0
END AS est_dernier_jour,
CASE
WHEN last_value(p_mouvements_articles.oid) OVER (PARTITION BY p_mouvements_articles.article_id, p_mouvements_articles.lieu_id, p_mouvements_articles.date ORDER BY p_mouvements_articles.oid) = p_mouvements_articles.oid THEN lead(p_mouvements_articles.date) OVER (PARTITION BY p_mouvements_articles.article_id, p_mouvements_articles.lieu_id ORDER BY p_mouvements_articles.date)
ELSE p_mouvements_articles.date
END AS date_fin
FROM eco.p_mouvements_articles
JOIN eco.t_types_mouvements ON p_mouvements_articles.type_mouvement_id = t_types_mouvements.oid
JOIN eco.t_sites ON p_mouvements_articles.site_id = t_sites.oid
JOIN eco.t_gestionnaires ON p_mouvements_articles.gestionnaire_id = t_gestionnaires.oid
JOIN eco.t_lieux ON p_mouvements_articles.lieu_id = t_lieux.oid
JOIN eco.t_articles ON p_mouvements_articles.article_id = t_articles.oid
JOIN eco.t_compte ON p_mouvements_articles.compte_id = t_compte.oid
JOIN eco.t_ucd_c ON p_mouvements_articles.ucd_id = t_ucd_c.oid
JOIN eco.t_lpp_c ON p_mouvements_articles.lpp_id = t_lpp_c.oid
JOIN eco.t_fournisseurs ON p_mouvements_articles.fournisseur_id = t_fournisseurs.oid
JOIN eco.t_unites_fonctionnelles ON p_mouvements_articles.unite_fonctionnelle_id = t_unites_fonctionnelles.oid;