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 :

Alternative à NOT IN


Sujet :

Langage SQL

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2019
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Alternative à NOT IN
    Bonjour,

    Je débute sur SQL, et je cherche une alternative a NOT IN.
    A titre d'exemple, j'ai deux tables Clients et Banque

    Table Clients
    id name
    1 Nom1
    2 Nom2
    3 Nom3
    4 Nom4

    Table Banque
    id event Payout_id
    1 Event1 3
    2 Event2 2
    3 Nom3 5
    4 Nom4 null


    Est-ce qu'il est possible d'utiliser deux valeurs de tables differentes id et payout_id comme ce code la ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * from Client where id NOT IN (SELECT payout_id from Banque)
    Existe t-il une autre solution pour ne pas utiliser NOT IN ?

    Merci beaucoup et bonne journée !

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 133
    Points : 38 556
    Points
    38 556
    Billets dans le blog
    9
    Par défaut
    Bonjour,

    Autrefois, NOT EXISTS était beaucoup plus performant que NOT IN , ce n'est plus toujours vrai de nos jours l'optimiseur sait traduire le NOT IN en NOT EXISTS.
    À tester au cas où votre version de SGBD serait un peu dépassée

    Ce qui donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    select CL.col1
         , CL.col2
         , ...
         , CL.coln
    from client as CL
    where not exists
         (select 1
          from banque as BQ
          where BQ.payout_id = CL.id
         )

  3. #3
    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 789
    Points
    30 789
    Par défaut
    Deux alternatives :
    1. Avec NOT EXISTS
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      8
      SELECT  * 
      FROM    Client  clt 
      WHERE   NOT EXISTS 
              (   SELECT  payout_id 
                  FROM    Banque  bnq
                  WHERE   bnq.payout_id = clt.id
              )
      ;
    2. Avec LEFT JOIN ... WHERE ... IS NULL
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      SELECT  * 
      FROM    Client  clt
          LEFT JOIN
              Banque  bnq
              ON  bnq.payout_id = clt.id
      WHERE   bnq.id  IS NULL
      ;
    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.

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 133
    Points : 38 556
    Points
    38 556
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par al1_24 Voir le message
    Deux alternatives :
    • Avec LEFT JOIN ... WHERE ... IS NULL
    Attention pour cette solution à bien vérifier qu'il s'agit d'une colonne NOT NULL qui ne peut donc être "null" que si la jointure outer n'est pas satisfaite

  5. #5
    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 789
    Points
    30 789
    Par défaut
    En effet, j'aurais du préciser WHERE tb2.pk IS NULL.
    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.

  6. #6
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2019
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    He bien ! Merci pour ces réponses rapides ! Vous m'avez bien aidé !! C'est exactement ce que je cherchais.

    Bonne journée !

  7. #7
    Expert éminent sénior
    Homme Profil pro
    Ingénieur d'Etude Mainframe/AS400
    Inscrit en
    Novembre 2012
    Messages
    1 767
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur d'Etude Mainframe/AS400
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2012
    Messages : 1 767
    Points : 10 764
    Points
    10 764
    Par défaut
    Bonjour, en DB2/AS400 (je ne sais pas si c'est possible sur MAINFRAME) on peut utiliser l'exception join qui est très élégant je trouve. Ce qui dans le cas présent donnerait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT cli.* from Client cli 
    exception join Banque bq on 
    bq.payout_id= cl.id

  8. #8
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 936
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 936
    Points : 4 356
    Points
    4 356
    Par défaut
    Citation Envoyé par al1_24 Voir le message
    Deux alternatives :
    + la technique du MINUS qui peut être efficace ici car PK et probablement FK sont utilisées
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    
    SELECT  * 
    FROM    Client  clt 
    WHERE   id IN 
    (   
    SELECT id FROM Client
    MINUS
    SELECT payout_id FROM Banque  
    )
    Comparez les plans avant de choisir.

  9. #9
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 133
    Points : 38 556
    Points
    38 556
    Billets dans le blog
    9
    Par défaut
    Bonjour,
    Citation Envoyé par Darkzinus Voir le message
    Bonjour, en DB2/AS400 (je ne sais pas si c'est possible sur MAINFRAME) on peut utiliser l'exception join qui est très élégant je trouve. Ce qui dans le cas présent donnerait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT cli.* from Client cli 
    exception join Banque bq on 
    bq.payout_id= cl.id
    C'est une spécificité DB2/400 (DB2 for system i)



    Citation Envoyé par JeitEmgie Voir le message
    + la technique du MINUS qui peut être efficace ici car PK et probablement FK sont utilisées
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    
    SELECT  * 
    FROM    Client  clt 
    WHERE   id IN 
    (   
    SELECT id FROM Client
    MINUS
    SELECT payout_id FROM Banque  
    )
    MINUS ou EXCEPT selon les SGBD

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

Discussions similaires

  1. alterner les couleurs dans un tableau avec xsl
    Par Eithelgul dans le forum XSL/XSLT/XPATH
    Réponses: 14
    Dernier message: 03/05/2015, 23h29
  2. [debutant]alternative à NOT IN
    Par sly33 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 19/06/2007, 11h02
  3. [Turbo C++] Fonciton containing for are not expanded inline
    Par BuG dans le forum Autres éditeurs
    Réponses: 6
    Dernier message: 17/02/2003, 06h48
  4. Component not found
    Par Pm dans le forum XMLRAD
    Réponses: 2
    Dernier message: 28/01/2003, 14h40
  5. "ALTERER" une col. NULL en NOT NULL - Int
    Par Gandalf24 dans le forum SQL
    Réponses: 2
    Dernier message: 28/12/2002, 00h07

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