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

MS SQL Server Discussion :

CONDITION dans un WHERE..NOT IN


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mars 2005
    Messages
    101
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 101
    Par défaut CONDITION dans un WHERE..NOT IN
    Bonjour,

    J'aimerai savoir si une telle requète est possible



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT [PK_LIGNE_ID],[FK_UNITE_ID],[FK_AGENT_ID],[OPERATEUR],[NUMERO_MOBILE],[TYPE_POSTE],[BLACKBERRY],[DATE_DEBUT],[DATE_FIN]   FROM table1
    WHERE ([FK_UNITE_ID],[FK_AGENT_ID]) NOT IN (SELECT [FK_UNITE_ID],[FK_AGENT_ID] FROM table2
    Merki !

  2. #2
    Membre averti
    Étudiant
    Inscrit en
    Avril 2008
    Messages
    14
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2008
    Messages : 14
    Par défaut
    ,
    la requete du type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT [PK_LIGNE_ID],[FK_UNITE_ID],[FK_AGENT_ID],[OPERATEUR],[NUMERO_MOBILE],[TYPE_POSTE],[BLACKBERRY],[DATE_DEBUT],[DATE_FIN]   FROM table1
    WHERE ([FK_UNITE_ID],[FK_AGENT_ID]) NOT IN (SELECT [FK_UNITE_ID],[FK_AGENT_ID] FROM table2)
    est correcte car tu met la condition d'une colonne ne se trouvant pas dans un ensemble donnée ou dans une liste qui est souvent la deuxième requête mais je pense que la condition ne se fait que sur une seule colonne s'il y a en plusieurs, il y a le mot "and" et "or" qui t'aideront à appliquer le filtre sur plusieurs conditions. mais mettre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    where (colonne1,colonne2) not in ...
    je pense que ça ne marchera pas.

    Je pense que ca va marché Bonne journée

  3. #3
    Membre averti
    Étudiant
    Inscrit en
    Avril 2008
    Messages
    14
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2008
    Messages : 14
    Par défaut
    ,
    la requete du type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT [PK_LIGNE_ID],[FK_UNITE_ID],[FK_AGENT_ID],[OPERATEUR],[NUMERO_MOBILE],[TYPE_POSTE],[BLACKBERRY],[DATE_DEBUT],[DATE_FIN]   FROM table1
    WHERE ([FK_UNITE_ID],[FK_AGENT_ID]) NOT IN (SELECT [FK_UNITE_ID],[FK_AGENT_ID] FROM table2)
    est presque correcte car tu met la condition d'une colonne ne se trouvant pas dans un ensemble donnée ou dans une liste qui est souvent la deuxième requête mais je pense que la condition ne se fait que sur une seule colonne s'il y a en plusieurs, il y a le mot "and" et "or" qui t'aideront à appliquer le filtre sur plusieurs conditions. Mais il faut pas mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     where (colonne1,colonne2) not in ...
    je pense que ça ne marchera pas mais plutôt
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     where colonne1 not in ... and colonne2
    marchera sinon

    Je pense que ca va marché Bonne journée

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    616
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Luxembourg

    Informations forums :
    Inscription : Mars 2007
    Messages : 616
    Par défaut
    Citation Envoyé par brasco06 Voir le message
    Bonjour,
    J'aimerai savoir si une telle requète est possible !
    Non, il faut faire une jointure externe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT [PK_LIGNE_ID],[FK_UNITE_ID],[FK_AGENT_ID],[OPERATEUR],[NUMERO_MOBILE],[TYPE_POSTE],[BLACKBERRY],[DATE_DEBUT],[DATE_FIN]   
    FROM table1 t1
    LEFT JOIN (SELECT [FK_UNITE_ID],[FK_AGENT_ID] FROM table2) t2
    	ON  t1.[FK_UNITE_ID] = t2.[FK_UNITE_ID]
    	AND t1.[FK_AGENT_ID] = t2.[FK_AGENT_ID]
    WHERE t2.[FK_UNITE_ID] IS NULL

  5. #5
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Je valide la proposition de cmako qui est plus propre puisque SARGable.
    On peut néanmoins simplifier un peu la requête :

    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
     
    SELECT T1.PK_LIGNE_ID,
    		T1.FK_UNITE_ID,
    		T1.FK_AGENT_ID,
    		T1.OPERATEUR,
    		T1.NUMERO_MOBILE,
    		T1.TYPE_POSTE,
    		T1.BLACKBERRY,
    		T1.DATE_DEBUT,
    		T1.DATE_FIN
    FROM dbo.table1 AS T1
    LEFT JOIN dbo.table2 AS T2
    	ON T1.FK_UNITE_ID = T2.FK_UNITE_ID
    	AND T1.FK_AGENT_ID = T2.FK_AGENT_ID
    WHERE T2.FK_UNITE_ID IS NULL
    AND T2.FK_AGENT_ID IS NULL
    @++

  6. #6
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    616
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Luxembourg

    Informations forums :
    Inscription : Mars 2007
    Messages : 616
    Par défaut
    Citation Envoyé par elsuket Voir le message
    Bonjour,

    Je valide la proposition de cmako qui est plus propre puisque SARGable.
    On peut néanmoins simplifier un peu la requête :
    @++
    Oui, ta solution est bonne mais il ne faut pas oublier que tu risques d'avoir des produits cartésiens. Même ma solution était incomplète il faut rajouter un DISTINCT
    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
    SELECT 
    	PK_LIGNE_ID
    	,FK_UNITE_ID
    	,FK_AGENT_ID
    	,OPERATEUR
    	,NUMERO_MOBILE
    	,TYPE_POSTE
    	,BLACKBERRY
    	,DATE_DEBUT
    	,DATE_FIN   
    FROM table1 t1
    LEFT JOIN (SELECT DISTINCT FK_UNITE_ID,FK_AGENT_ID FROM table2) t2
    	ON  t1.FK_UNITE_ID = t2.FK_UNITE_ID
    	AND t1.FK_AGENT_ID = t2.FK_AGENT_ID
    WHERE t2.FK_UNITE_ID IS NULL

Discussions similaires

  1. [MySQL] Conditions dans un WHERE
    Par laipreu dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 02/01/2012, 15h02
  2. [Doctrine] Requête select imbriquée dans un where not in
    Par Herode dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 28/03/2011, 14h43
  3. Inclure une Condition dans un "Where"
    Par the dude dans le forum Langage SQL
    Réponses: 4
    Dernier message: 22/02/2011, 08h42
  4. Une condition dans le where
    Par logiciel_const dans le forum SQL
    Réponses: 2
    Dernier message: 31/01/2011, 18h47
  5. Condition dans un where ?
    Par devdev dans le forum Débuter
    Réponses: 7
    Dernier message: 28/08/2008, 12h05

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