IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Requêtes PostgreSQL Discussion :

ERROR:SQL state: 42712. ERREUR: le nom de la table « l » est spécifié plus d'une fois [8.3]


Sujet :

Requêtes PostgreSQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Septembre 2018
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Niger

    Informations professionnelles :
    Activité : Auditeur informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Septembre 2018
    Messages : 58
    Par défaut ERROR:SQL state: 42712. ERREUR: le nom de la table « l » est spécifié plus d'une fois
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    SELECT substr(c.code_activite,1,3)progrrmme, c.section_code, c.code_activite, c.intitule_activite,
      c.categorie_depense_code, c.montant_initiale, c.montant_libere, c.montant_engage,c.montant_delegue,
      (c.montant_engage+c.montant_delegue)Consomme,( c.montant_initiale- c.montant_libere)Bloqué,
       (c.montant_libere-(c.montant_engage+c.montant_delegue))Disponible,l.who_done, l.when_done, l.montant_disponible_cp, 
       l.montant_total_engagement_ttc, l.montant_total_liquidation_ttc
    	FROM situation.cumuls_activite_ae c ,depense.v_liquidations l
    	LEFT JOIN depense.v_liquidations l on  c.section_code=substr(l.liquidation,3,2)
    	LEFT JOIN situation.cumuls_activite_ae c on l.categorie=c.categorie_depense_code
    	where c.section_code='05' and  c.categorie_depense_code <>'2' and l.categorie <>'2' 
    	 and date(l.when_done) BETWEEN '2021-01-01' and '2021-06-30'
    	and l.who_done like 'zoumarou%'
    	Group by substr(c.code_activite,1,3), c.section_code, c.code_activite, c.intitule_activite, c.categorie_depense_code,
    	c.montant_initiale, c.montant_libere, c.montant_engage,    c.montant_delegue,l.who_done, l.when_done, 
    	l.montant_disponible_cp, l.montant_total_engagement_ttc, l.montant_total_liquidation_ttc
    	having  sum(c.montant_libere)>0
    	order by substr(c.code_activite,1,3), c.section_code, c.code_activite, c.intitule_activite, c.categorie_depense_code,
    	c.montant_initiale, c.montant_libere, c.montant_engage, c.montant_delegue,l.who_done, l.when_done, 
    	l.montant_disponible_cp, l.montant_total_engagement_ttc, l.montant_total_liquidation_ttc

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 009
    Billets dans le blog
    6
    Par défaut
    Le message est clair ! Vous avez deux fois l'alias de table "l" (L)

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre confirmé
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Septembre 2018
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Niger

    Informations professionnelles :
    Activité : Auditeur informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Septembre 2018
    Messages : 58
    Par défaut
    Bjr. Le resultat s'affiche mais J'ai de doublons dans l'affichage de données
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    SELECT substr(c.code_activite,1,3)progrrmme, c.section_code, c.code_activite, c.intitule_activite,
      c.categorie_depense_code, c.montant_initiale, c.montant_libere, c.montant_engage,c.montant_delegue,
      (c.montant_engage+c.montant_delegue)Consomme,( c.montant_initiale- c.montant_libere)Bloqué,
       (c.montant_libere-(c.montant_engage+c.montant_delegue))Disponible,l.who_done, l.when_done, l.montant_disponible_cp
     
    	FROM situation.cumuls_activite_ae c 
    	LEFT JOIN depense.v_liquidations l on  c.section_code=substr(l.liquidation,3,2)
     
    	where c.section_code='05'  and  c.categorie_depense_code <>'2'  and c.categorie_depense_code = l.categorie 
    	 and date(l.when_done) BETWEEN '2021-01-01' and '2021-06-30' and l.who_done like 'zoumarou%'
    	Group by substr(c.code_activite,1,3), c.section_code, c.code_activite, c.intitule_activite, c.categorie_depense_code,
    	c.montant_initiale, c.montant_libere, c.montant_engage,c.montant_delegue,l.who_done, l.when_done, 
    	l.montant_disponible_cp
    	having  sum(c.montant_libere)>0
    	order by substr(c.code_activite,1,3), c.section_code, c.code_activite, c.intitule_activite, c.categorie_depense_code,
    	c.montant_initiale, c.montant_libere, c.montant_engage,    c.montant_delegue,l.who_done, l.when_done, 
    	l.montant_disponible_cp

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 137
    Par défaut
    Bonjour,

    Des doublons ? Ce serait étonnant à la lecture de la clause GROUP BY.
    Comment se présentent-ils ?

    En attendant plus de précisions, il faudrait revoir la mise en forme de cette requête afin d'y voir un peu plus clair :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    SELECT  SUBSTR(c.code_activite,1,3) progrrmme
        ,   c.section_code
        ,   c.code_activite
        ,   c.intitule_activite
        ,   c.categorie_depense_code
        ,   c.montant_initiale
        ,   c.montant_libere
        ,   c.montant_engage
        ,   c.montant_delegue
        ,   ( c.montant_engage + c.montant_delegue)     Consomme
        ,   ( c.montant_initiale - c.montant_libere)    Bloqué
        ,   ( c.montant_libere - (c.montant_engage + c.montant_delegue))    Disponible
        ,   l.who_done
        ,   l.when_done
        ,   l.montant_disponible_cp
    FROM    situation.cumuls_activite_ae c 
        LEFT JOIN 
            depense.v_liquidations      l
            ON  c.section_code  = SUBSTR(l.liquidation, 3, 2)
    WHERE   c.section_code = '05'  
        AND c.categorie_depense_code <> '2'
        AND c.categorie_depense_code = l.categorie 
        AND DATE(l.when_done) BETWEEN '2021-01-01' AND '2021-06-30' 
        AND l.who_done LIKE 'zoumarou%'
    GROUP BY SUBSTR(c.code_activite,1,3)
        ,   c.section_code
        ,   c.code_activite
        ,   c.intitule_activite
        ,   c.categorie_depense_code
        ,   c.montant_initiale
        ,   c.montant_libere
        ,   c.montant_engage
        ,   c.montant_delegue
        ,   l.who_done
        ,   l.when_done
        ,   l.montant_disponible_cp
    HAVING  SUM(c.montant_libere) > 0
    ORDER BY SUBSTR(c.code_activite, 1, 3)
        ,   c.section_code
        ,   c.code_activite
        ,   c.intitule_activite
        ,   c.categorie_depense_code
        ,   c.montant_initiale
        ,   c.montant_libere
        ,   c.montant_engage
        ,   c.montant_delegue
        ,   l.who_done
        ,   l.when_done
        ,   l.montant_disponible_cp
    Et là il apparait :
    • Ligne 22, une condition de jointure qui n'a rien à faire dans la clause WHERE
    • Lignes 23-24, des restrictions sur la table v_liquidations qui transforment la jointure externe attendue en jointure stricte
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. mail envoyé plus qu'une fois par erreur
    Par pascb423 dans le forum Langage
    Réponses: 2
    Dernier message: 29/01/2020, 12h43
  2. Réponses: 2
    Dernier message: 18/07/2016, 11h04
  3. Réponses: 3
    Dernier message: 25/03/2015, 16h01
  4. Requete SQL qui ne retourne rien alors que ma table n est pas vide
    Par adelsunwind dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 02/06/2009, 20h16
  5. Réponses: 5
    Dernier message: 13/03/2009, 11h57

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo