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 MySQL Discussion :

Sélection parmi une liste les valeurs qui ne sont pas dans une table


Sujet :

Requêtes MySQL

  1. #1
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Points : 658
    Points
    658
    Par défaut Sélection parmi une liste les valeurs qui ne sont pas dans une table
    Bonjour à tous, décidément j'ai souvent des problèmes

    Voilà, avec mon code php, j'obtiens une liste de valeurs.

    Je voudrais dans une requête sélectionner parmi cette liste celles qui ne sont pas dans ma table.

    J'ai par exemple dans une colonne d'une table les valeurs 1, 2, 3
    De l'autre côté(mon code php), j'obtiens une liste de 1, 2, 3, 4

    Donc, je souhaite obtenir 4 comme résultat de ma requête.

    J'ai tenté des jointures, mais je n'arrive pas à obtenir ce résultat.

    Est-ce possible de faire cela ?

  2. #2
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    En PHP :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $liste = '1, 2, 3, 4';
    $sql = "SELECT val FROM ta_table WHERE val NOT IN ($liste)" ;
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  3. #3
    Membre confirmé Avatar de amika
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    498
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Septembre 2004
    Messages : 498
    Points : 464
    Points
    464
    Par défaut
    Citation Envoyé par Antoun
    $liste = '1, 2, 3, 4';
    $sql = "SELECT val FROM ta_table WHERE val NOT IN ($liste)" ;
    cette requette donne un resultat vide. avec liste(1,2,3,4) et table (1,2,3).
    lui veut une chose comme select val in liste where val not in table

    _____________________
    Il n'y a pas de choses urgentes, il n'y a que des choses en retard

  4. #4
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Points : 658
    Points
    658
    Par défaut
    Non, ce n'est pas ce que je veux.

    Là avec ceci, ça va me renvoyer toutes les autres valeurs de ma table qui ne sont pas dans cette liste.

    Or ce que je désire, c'est le contraire, donc avoir pour résultat les éléments de la liste qui ne sont pas dans la table.

    Ah oui, c'est vrai qu'avec mon exemple, la requête ne donnera aucun résultat, puisqu'il sont tous dans la table

  5. #5
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    oups, désolé !
    il faut que tu crées une table temporaire dans laquelle tu injectes ta liste PHP, et qu'ensuite tu fasses une requête de non-correspondance.
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  6. #6
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Points : 658
    Points
    658
    Par défaut
    Y'a vraiment pas d'autre solution ?

    J'ai vu qu'en SQL, il existait la fonction UNNEST qui permettait de transformer une liste de valeurs en colonne de table, y'a pas un équivalent de ça chez MySQL ?
    Ou une alternative ?

    Sinon, tant pis, je vais revoir mon php, je ne peux pas me permettre de créer une table temp et d'y insérer des données, pour extraire celle qui m'intéresse.

  7. #7
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    C'est difficile de demander à MySQL de ressortir des données qui ne sont PAS dans la base.

    Tu peux toujours faire comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    $liste = '1, 2, 3, 4';
    $liste2 = str_replace(', ', ' AS Val UNION ALL SELECT ', $liste) ;
    $sql = "SELECT Val 
      FROM (SELECT $liste2 AS Val) AS PHP
        LEFT OUTER JOIN ta_table T ON PHP.Val = T.Val
      WHERE T.Val IS NULL" ;
    Du coup tu n'as pas à faire toi-même le CREATE TEMPORARY TABLE. Mais la triste réalité est que MySQL implémente les sous-requêtes du FROM (comme "PHP") en créant silencieusement une table temporaire.
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  8. #8
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Points : 658
    Points
    658
    Par défaut
    Sachant que dans ma liste, il peut y avoir jusqu'à 9 valeurs, ça risque de devenir super lourd avec des UNION, d'autant que la page qui l'utilisera sera assez fréquentée.

    Tant pis, j'abandonne l'idée

    Merci de ton aide

  9. #9
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    9 valeurs, c'est peanuts ! Tu m'aurais dit 200, je te dirais que c'est effectivement assez lourd, mais à 9 tu peux y aller sans problème... et plutôt avec une table temporaire et un INSERT multilignes qu'avec des UNION :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    INSERT INTO tempo (colonne)
    VALUES (1), (2), (3), ...
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  10. #10
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Points : 658
    Points
    658
    Par défaut
    T'es sûr ?

    M'enfin, ça m'oblige quand même à faire 2 requêtes préalables pour créer cette table.
    Ca m'ennuie beaucoup.

    Non pas que je suis radin en requêtes , loin de là, mais j'essaie de réduire au minimum le nombre de celles-ci, pour ne pas me retrouver au final avec des pages avec plus de 20 requêtes.

  11. #11
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    Teste et mesure !
    Tu as la solution à une seule requête avec les UNION, la solution à trois requêtes avec CREATE puis INSERT, une solution intermédiaire à deux requêtes avec un CREATE...SELECT... UNION.

    Pense également que la communication PHP/MySQL est lente pour les SELECT, qui renvoient un jeu de données, mais moins pour les autres qui n'en renvoient pas.

    Pense également qu'avec PHP5 et MySQLi, tu as multi_query.

    Enfin, si tes 9 valeurs sont toujours les mêmes, le mieux est encore de créer une bonne fois pour toute une table non temporaire qui les contiennent toutes. Cela te permet ensuite de faire tout en une seule requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    $liste = '1, 2, 3, 4';
    $sql = "SELECT L9.Val
      FROM Liste9 L9
         LEFT OUTER JOIN ta_table T ON L9.Val = T.Val
      WHERE T.Val IS NULL
        AND L9.Val IN($liste) ; "
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

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

Discussions similaires

  1. supprimer les fichiers qui ne sont pas dans une liste
    Par jeorcal dans le forum Langage
    Réponses: 7
    Dernier message: 15/01/2011, 10h03
  2. Lister les enregistrements qui ne sont pas dans une table
    Par toss.net dans le forum Langage SQL
    Réponses: 3
    Dernier message: 04/10/2010, 11h25
  3. [RegEx] Lister des patterns qui ne sont pas dans une liste
    Par guidav dans le forum Langage
    Réponses: 2
    Dernier message: 28/12/2007, 18h14
  4. Faire une liste d'élément qui ne sont pas dans la base
    Par bossLINDROS dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 06/06/2007, 12h09
  5. Réponses: 1
    Dernier message: 21/12/2006, 11h17

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