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

Langage SQL Discussion :

[SQL] Problème avec une requête


Sujet :

Langage SQL

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 3
    Points : 1
    Points
    1
    Par défaut [SQL] Problème avec une requête
    Bonjour !

    Début Requête ----------------------------------------------------------
    SELECT Equipements.IDEquipements, Equipements.Num_Serie, LignesOp.Num_Ligne, Marques.Nom_Marque, Modèles.Nom_Modèle,
    Equipements.Date_Vente, Equipements.Date_Garantie, Equipements.Prix, Equipements.Reference,
    Utilisateurs.Nom_Uti + ' ' + Utilisateurs.Pre_Uti AS NomUti, Equipements.DateFin
    FROM Utilisateurs, Marques, Modèles, Equipements
    LEFT OUTER JOIN LignesOp
    ON Equipements.IdLignesOp = LignesOp.IDLignesOp
    WHERE Equipements.IDClients = 597
    AND Equipements.Type_Equipement = 1
    AND Marques.IDMarques = Equipements.IDMarques
    AND Modèles.IDModèles = Equipements.IDModèles
    AND LignesOp.IDUserOperateur = Utilisateurs.IDUTILISATEURS
    FIN Requete------------------------------------------------------------

    J'ai certains enregistrements qui ont LignesOp.IDUserOperateur à 0 alors qu'il n'ya pas d'enregsitrement dans le fichier Utilisateurs avec IDUTILISATEURS à zéro (et qu'il ne peut pas y en avoir). Ces enregistrements ne sont donc pas affichés, alors que j'aimerais qu'ils le soient, et en une seule requête.

    Si qqun a une idée, merci !

    Jean-Christophe

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Commence par écrire ton code avec des jointures normalisées et ça fonctionnera tout de suite mieux.
    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
    SELECT    Equipements.IDEquipements
        ,    Equipements.Num_Serie
        ,    LignesOp.Num_Ligne
        ,    Marques.Nom_Marque
        ,    Modèles.Nom_Modèle
        ,    Equipements.Date_Vente
        ,    Equipements.Date_Garantie
        ,    Equipements.Prix
        ,    Equipements.Reference
        ,    Utilisateurs.Nom_Uti + ' ' + Utilisateurs.Pre_Uti AS NomUti
        ,    Equipements.DateFin
    FROM     Equipements
        INNER JOIN
            Marques
            ON Marques.IDMarques = Equipements.IDMarques
        INNER JOIN
            Modèles
            ON    Modèles.IDModèles = Equipements.IDModèles
        LEFT OUTER JOIN 
            LignesOp
            ON Equipements.IdLignesOp = LignesOp.IDLignesOp
        INNER JOIN
            Utilisateurs
            ON LignesOp.IDUserOperateur = Utilisateurs.IDUTILISATEURS
    WHERE     Equipements.IDClients = 597
        AND Equipements.Type_Equipement = 1
    ;
    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.

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Merci pour ta réponse, al1_24

    Bah j'ai utilisé ta reqête, et j'ai exactement le même résultat, mes enregistrements don l'IDUserOperateur est à zéro n'apparaissent toujours pas !

    Merci

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Et avec une jointure externe ?
    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    ...
    FROM     Equipements
        INNER JOIN
            Marques
            ON Marques.IDMarques = Equipements.IDMarques
        INNER JOIN
            Modèles
            ON    Modèles.IDModèles = Equipements.IDModèles
        LEFT OUTER JOIN 
            LignesOp
            ON Equipements.IdLignesOp = LignesOp.IDLignesOp
        LEFT OUTER JOIN
            Utilisateurs
            ON LignesOp.IDUserOperateur = Utilisateurs.IDUTILISATEURS
    WHERE     Equipements.IDClients = 597
        AND Equipements.Type_Equipement = 1
    ;
    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.

  5. #5
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    J'avais déjà essayé, et c'est pas mieux

Discussions similaires

  1. [SQL] problème avec une requête
    Par ANISSS dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 23/05/2007, 17h56
  2. [SQL] Problème avec une requête sql
    Par bodysplash007 dans le forum PHP & Base de données
    Réponses: 22
    Dernier message: 11/05/2007, 17h30
  3. [MySQL] Problème avec une requête SQL
    Par chobol dans le forum PHP & Base de données
    Réponses: 12
    Dernier message: 11/05/2006, 12h29
  4. [SQL Server]Problème avec une requête récursive
    Par evans dans le forum Langage SQL
    Réponses: 3
    Dernier message: 05/04/2006, 20h16
  5. [VB]Problème avec une requête SQL
    Par Tyrael62 dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 18/03/2006, 17h47

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