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 :

Requête avec exclusion


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 6
    Points : 6
    Points
    6
    Par défaut Requête avec exclusion
    Bonjour je souhaite obtenir des enregistrements dans une table issus d'une requete de selection de la table lmc_altcell (ac)

    le couple (ac.name, ac.code_partition) ne doit pas exister dans almc_cell
    voici la requete que j'ai construite:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT 0,'CHK010', ac.name, ac.code_partition, adms.code, null, null, null, null, null, null, null
    			FROM lmc_altcell ac, adm_status adms 
    			WHERE adms.id = ac.id_status AND adms.code <> 'DEV'
    			AND (ac.name, ac.code_partition) NOT IN (SELECT altcellname, partition  FROM almc_cell)
    le souci est que j'ai un vecteur de test que j'aimerais bien retrouver dans mon enregistrement, mais je ne le retrouve pas.
    le couple existe dans la table lmc_altcell mais pas dans la table almc_cell. Je m'attends donc à le retrouver dans mon SELECT, mais je ne le trouve pas...

    pouvez-vous m'aider?

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour

    Vous pouvez utiliser NOT EXISTS :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT 0,'CHK010', ac.name, ac.code_partition, adms.code, null, null, null, null, null, null, null
    FROM lmc_altcell ac, adm_status adms
    WHERE adms.id = ac.id_status AND adms.code <> 'DEV'
    AND NOT EXISTS (
        SELECT *
        FROM almc_cell
        WHERE altcellname= ac.name, 
        AND partition = ac.code_partition)

    ou faire une jointure externe et évaluer la nullité des colonnes de la table almc_cell

  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 803
    Points
    30 803
    Par défaut
    Es-tu certain que le couple que tu t'attends à trouver répond à tous les critères de la sélection ?
    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
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    J'avais la meme idée que aieeeuuuuu (les jointures en plus)

    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 
    	0,'CHK010', ac.name, ac.code_partition, adms.code, NULL, NULL, NULL, NULL, NULL, NULL, NULL
    FROM 
    	lmc_altcell ac inner join adm_status adms on (adms.id = ac.id_status)
    WHERE 
    	adms.code <> 'DEV'
    	AND NOT EXISTS 
    	(
    	 SELECT
    		1
    	 FROM
    		almc_cell 
    	 WHERE
    		ac.name = almc_cell.name 
    		AND ac.code_partition = almc_cell.code_partition
    	)
    Dans la connaissance du monde, ceux qui ne savent rien en savent toujours autant que ceux qui n'en savent pas plus qu'eux. (Pierre Dac)

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    nickel ca fonctionne!

    merci à tous!

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

Discussions similaires

  1. [2005] Optimisation requête avec exclusions
    Par Mizar31 dans le forum Développement
    Réponses: 21
    Dernier message: 24/02/2015, 09h55
  2. Requête avec exclusion
    Par Angelik dans le forum Requêtes
    Réponses: 2
    Dernier message: 07/11/2013, 11h47
  3. [MySQL] requête avec exclusion
    Par nicomax34 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 23/09/2011, 18h40
  4. Requête avec exclusion de colonnes
    Par lemfi dans le forum Langage SQL
    Réponses: 8
    Dernier message: 31/01/2008, 13h38
  5. Requête avec exclusion
    Par illegalsene dans le forum Langage SQL
    Réponses: 5
    Dernier message: 01/02/2006, 11h07

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