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

 MySQL Discussion :

Comparer 2 tables à l'identiques


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut Comparer 2 tables à l'identiques
    Bonjour,

    Dans mon projet, je dois comparer si 2 tables sont parfaitement identiques.
    Les enregistrements de la Table 1 doivent être à l'identiques aux enregistrements de la table 2.

    J'ai bien tenté avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT *
    FROM t_Serveur as TS
    WHERE NOT EXISTS (	SELECT NULL
    					FROM t_clients as TC
    					WHERE TS.ID LIKE TC.ID)
    Mais ceci ne fonctionne que pour comparer la colonne ID entre les 2 tables.
    Or, je voudrais comparer toutes les colonnes et qu'il y ait toujours la même correspondance entre les 2 tables. En gros il faut qu'elles soient parfaitement identiques à l'enregistrement près.

    Les colonnes sont :
    ID, Colonne1, Colonne2, Colonne3, Colonne4
    Les 2 tables ont exactement la même structure. Il n'y a que les enregistrements qui peuvent différer.

    Et si il existe des enregistrements non identiques, je dois retourner toute la ligne, que la différence soit dans la colonne ID ou Colonne1, ou Colonn2, ou Colonne3 ou Colonne4.

    Merci pour votre rapide aide.

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select *
    from t_Serveur AS TS
      full join  t_Client AS TC ON TS.ID = TS.ID
    where TS.Colonne1 <> TC.Colonne1
      or TS.Colonne2 <> TC.Colonne2
      or TS.Colonne3 <> TC.Colonne3
      or TS.Colonne4 <> TC.Colonne4
      or TS.ID IS NULL
      or TC.ID IS NULL

  3. #3
    Membre émérite Avatar de Oishiiii
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 508
    Par défaut
    Il me semble bien que MySQL ne propose pas de jointure "totale" (FULL [OUTER] JOIN).

    J'utiliserai NOT IN() et UNION comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT id, colonne1, colonne2, colonne3, 't_serveur' AS tableSource
    FROM t_serveur
    WHERE (id, colonne1, colonne2, colonne3) NOT IN (
      SELECT id, colonne1, colonne2, colonne3
      FROM t_clients
    )
    UNION ALL
    SELECT id, colonne1, colonne2, colonne3, 't_clients' AS tableSource
    FROM t_clients
    WHERE (id, colonne1, colonne2, colonne3) NOT IN (
      SELECT id, colonne1, colonne2, colonne3
      FROM t_serveur
    )
    J'ai ajouté une colonne pour identifier la table d'où vient la ligne.

    A tester.

  4. #4
    Membre confirmé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut
    Merci

    PhpMyAdmin me renvoi une erreur lorsque j'exécute la requête :

    #1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'full JOIN t_Clients AS TC ON TS.ID = TS.ID WHERE TS.Colonne1' at line 3
    Que faire ?
    Je me serais trompé qq part en renommant les tables ou colonnes ? Mais je ne penses pas après vérification.

  5. #5
    Membre confirmé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut
    Je viens d'essayer la 2è requete.
    Et ça me retourne bien les erreurs, c'est cool.
    Merci

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Citation Envoyé par Korben-Dallas Voir le message
    Je me serais trompé qq part en renommant les tables ou colonnes ? Mais je ne penses pas après vérification.
    Non, Oishiii a raison, MySQL ne fait pas le FULL JOIN.

    Tu peux utiliser sa requête. Voici également un correctif de la mienne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT *
    FROM t_Serveur AS TS
      LEFT JOIN  t_Client AS TC ON TS.ID = TS.ID
    WHERE TS.Colonne1 <> TC.Colonne1
      OR TS.Colonne2 <> TC.Colonne2
      OR TS.Colonne3 <> TC.Colonne3
      OR TS.Colonne4 <> TC.Colonne4
      OR TC.ID IS NULL
    UNION ALL
    SELECT *
    FROM t_Serveur AS TS
      RIGHT JOIN  t_Client AS TC ON TS.ID = TS.ID
    WHERE TC.ID IS NULL

  7. #7
    Membre confirmé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut
    Désolé Antoine, ta correction n'apporte pas les données attendues.
    En fait, elle compare chaque ligne de la TS avec toutes les lignes de la TC ou inversement (je n'ai pas bien regardé).
    Ce n'est donc pas correct.
    Merci à toi tout de même et merci à Oishiii pour ta requête qui fonctionne bien.

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

Discussions similaires

  1. Comparer 2 tables sans checker chaque row
    Par BoOom dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 04/05/2006, 14h21
  2. [C#][VS2k5]Comparer 2 tables sans checker chaque row?
    Par BoOom dans le forum Windows Forms
    Réponses: 5
    Dernier message: 25/04/2006, 16h27
  3. Comparer 2 tables de structure identique.
    Par FMaz dans le forum Requêtes
    Réponses: 13
    Dernier message: 31/03/2006, 23h48
  4. Réponses: 7
    Dernier message: 20/02/2006, 17h18
  5. [MySQL] Comparer 2 tables
    Par v4np13 dans le forum PHP & Base de données
    Réponses: 20
    Dernier message: 20/10/2005, 19h18

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