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 :

suppression sous SQL Server


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2007
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 20
    Points : 13
    Points
    13
    Par défaut suppression sous SQL Server
    Bonjour à tous

    J'ai 2 tables identiques A et B avec à chaque fois une clé primaire composée de deux champs.

    J'aimerai supprimer les enregistrements de la table B qui existent dans A. Je connais le principe du IN mais je ne sais pas comment l'utiliser avec mes 2 champs. J'ai essayé une clause where composée de 2 IN ou encore imbriqués mais rien n'y fait.

    Merci d'avance pour votre aide

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    861
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 861
    Points : 965
    Points
    965
    Par défaut
    Bonjour,

    Je ne sais pas si SQL Server accepte cette syntaxe, c'est le cas pour Oracle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    DELETE FROM B
    WHERE (B.id1, B.id2) IN (SELECT id1, id2 FROM A);
    Sinon, tu peux utiliser un EXISTS :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    DELETE FROM B
    WHERE EXISTS (
    	  		 SELECT * FROM A
    			 WHERE A.id1 = B.id1
    			   AND A.id2 = B.id2
    			 );

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2007
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 20
    Points : 13
    Points
    13
    Par défaut
    Citation Envoyé par Snipah Voir le message
    Bonjour,

    Je ne sais pas si SQL Server accepte cette syntaxe, c'est le cas pour Oracle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    DELETE FROM B
    WHERE (B.id1, B.id2) IN (SELECT id1, id2 FROM A);
    Sinon, tu peux utiliser un EXISTS :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    DELETE FROM B
    WHERE EXISTS (
    	  		 SELECT * FROM A
    			 WHERE A.id1 = B.id1
    			   AND A.id2 = B.id2
    			 );
    Alors effectivement la première solution ne fonctionne pas sous SQL Server mais la seconde c'est nickel. Merci beaucoup j'avais complêtemenet oublié le fameux EXISTS bien pratique!

    Merci

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

Discussions similaires

  1. Equivalent de rownum sous SQL server
    Par Isildur dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 27/07/2009, 16h48
  2. Pb avec DROP COLUMN sous SQL Server 2000
    Par debailleul dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 03/03/2004, 15h38
  3. Heure sous SQL SERVER
    Par kisscoolfresh dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 30/01/2004, 18h43
  4. Convertir un type de donnée sous SQL Server
    Par Fleep dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 19/08/2003, 16h15
  5. MAJ d'une table sous SQL Server par insertion
    Par keish dans le forum Langage SQL
    Réponses: 6
    Dernier message: 11/06/2003, 17h23

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