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 et SQL. Discussion :

Problème sur requête Union [AC-2007]


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 233
    Points : 63
    Points
    63
    Par défaut Problème sur requête Union
    Bonjour,

    J'ai un petit problème sur une requête Union, j'ai associé 2 requêtes jusque là pas de souci, je voudrais ajouter une 3ème requête mais j'ai un message d'erreur comme quoi le nombre de colonnes ne correspond pas...

    Requête Union :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT [Table_Saisie inter].[N° CTA], [Table_Saisie inter].[Date intervention], Table_Sinistre.Sinistre, Table_SP.Nom, Table_SP.Prénom
    FROM Table_Sinistre INNER JOIN (Table_SP INNER JOIN [Table_Saisie inter] ON Table_SP.Matricule = [Table_Saisie inter].Matricule.Value) ON Table_Sinistre.N° = [Table_Saisie inter].Sinistre
    WHERE ((([Table_Saisie inter].[Date intervention]) Between [Formulaires]![Récap par mois]![Datededebut] And [Formulaires]![Récap par mois]![Datedefin]))
    UNION SELECT [Table_saisie divers].[N° CTA], [Table_saisie divers].[Date Inter], [Table_sinistre divers].Nature, Table_SP.Nom, Table_SP.Prénom
    FROM Table_SP INNER JOIN ([Table_sinistre divers] INNER JOIN [Table_saisie divers] ON [Table_sinistre divers].N° = [Table_saisie divers].Nature) ON Table_SP.Matricule = [Table_saisie divers].Matricule.Value
    WHERE ((([Table_saisie divers].[Date Inter]) Between [Formulaires]![Récap par mois]![Datededebut] And [Formulaires]![Récap par mois]![Datedefin]));
    requête à ajouter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT [Table_Saisie inter].[N° CTA], [Table_Saisie inter].[Date intervention], Table_Sinistre.Sinistre, Table_SP.Nom, Table_SP.Prénom
    FROM ([Table_Catégorie sinistre] INNER JOIN Table_Sinistre ON [Table_Catégorie sinistre].N° = Table_Sinistre.Catégorie) INNER JOIN ([Table_Saisie inter] INNER JOIN Table_SP ON [Table_Saisie inter].[Départ annulé].Value = Table_SP.Matricule) ON Table_Sinistre.N° = [Table_Saisie inter].Sinistre
    Merci pour votre aide

    Manu

  2. #2
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 855
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 855
    Points : 14 966
    Points
    14 966
    Par défaut
    Bonsoir,
    à tout hasard , essaie d'insérer la 3ème requête entre la 1ère et la 2ème car il se peut que le nom des champs puisse perturber Access lors de la constitution de la requête

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 233
    Points : 63
    Points
    63
    Par défaut
    Bonjour,

    Je viens d essayer mais toujours le même problème,!!
    Déja je me pose la question de savoir si il est possible de faire une union de 3 requêtes? ??

  4. #4
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 368
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 368
    Points : 23 840
    Points
    23 840
    Par défaut
    Les requêtes UNION peuvent devenir rapidement illisibles.

    Je recommande de faire une requête séparée par source puis de faire la requête union suivante :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select * from Requête1
    union select * from Requête2
    union select * from Requête3

    ce qui rend le débugage de chaque partie BEAUCOUP plus facile.

    Et en effet il faut impérativement que Requête1, 2 et 3 aient exactement le même nombre de champs.

    A+

  5. #5
    Membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 233
    Points : 63
    Points
    63
    Par défaut
    Bonjour,

    Merci de votre conseil, ça fonctionne très bien comme ça !!!

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

Discussions similaires

  1. GROUP BY sur requête UNION
    Par DoubleClic dans le forum Requêtes
    Réponses: 6
    Dernier message: 02/02/2010, 14h26
  2. Réponses: 2
    Dernier message: 15/12/2006, 16h19
  3. Problème sur requête : erreur 1111
    Par tiger33 dans le forum Requêtes
    Réponses: 4
    Dernier message: 25/10/2006, 13h30
  4. problème sur requête ajout
    Par yoruichi93 dans le forum Access
    Réponses: 7
    Dernier message: 10/05/2006, 15h51
  5. Problème sur requête insert mysql
    Par kcizth dans le forum Requêtes
    Réponses: 5
    Dernier message: 04/02/2006, 19h37

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