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

Bases de données Delphi Discussion :

Requêtes imbriquées pour la recherche de différences


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 13
    Points : 14
    Points
    14
    Par défaut Requêtes imbriquées pour la recherche de différences
    Bonjour, je cherche à trouver les différences entre 2 tables MySQL sous Delphi 7

    La requete que j'utilise retourne l'erreur : more than one row

    Voici la requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * FROM infor 
      WHERE ref = (SELECT ref FROM exchange) 
          and tel != (SELECT tel FROM exchange)
    La structure semble cependant cohérente car la requete suivante passe très bien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * FROM infor 
      WHERE ref NOT IN (SELECT ref FROM exchange) 
      ORDER BY entreprise
    Quelqu'un serait il en mesure de me "corriger" la requete ou alors de m'indiquer de très bonnes sources concernant les requetes complexes ?

    D'avance merci

    Kirian

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Fait plutot comme ci dessous, ca fonctionnera mieux ^^

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Select * from 
      infor as i inner join exchange as e on (i.ref = e.ref and i.tel <> e.tel)
    ORDER BY entreprise

  3. #3
    Membre éprouvé Avatar de Yurck
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 15
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2005
    Messages : 682
    Points : 912
    Points
    912
    Par défaut
    Bonjour,

    ton problème SQL vient du fait que l'opérateur "=" compare deux valeur de même type or tu lui poposes la comparaison entre la valeur d'un champ et une liste de valeur de ce champ.

    Tu dois donc changer d'opérateur et remplacer le "=" par l'opérateur parmi : "in".




    cordialement

  4. #4
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 13
    Points : 14
    Points
    14
    Par défaut
    Merci pour vos réponses...

    dans un premier temps j'ai remplacé le "=" par IN et le "!=" par NOT IN
    ca a l'air de marcher.
    Je vais essayer l'autre proposition

    Kirian

  5. #5
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Pour optimiser tes requetes : http://sql.developpez.com/optimiser/#L9

    Dans ton cas c'est le N°10 qu'il faut regarder

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

Discussions similaires

  1. Variables et requête imbriqué pour du dénombrement
    Par Ceubex dans le forum Requêtes
    Réponses: 2
    Dernier message: 30/07/2012, 15h55
  2. Réponses: 8
    Dernier message: 04/08/2010, 20h14
  3. Problème requête sql pour une recherche
    Par Zoldik dans le forum Langage SQL
    Réponses: 21
    Dernier message: 03/03/2009, 14h01
  4. Requête pour une recherche sur champs multiple d'une table
    Par fred777 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 07/10/2008, 16h33
  5. [SQL] Comment feriez-vous cette requête pour une recherche ?
    Par Core8 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 06/02/2008, 11h58

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