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

Développement SQL Server Discussion :

T-SQL equiv de la clause WHERE (col1, col2,)IN(select )


Sujet :

Développement SQL Server

  1. #1
    Futur Membre du Club
    Inscrit en
    Août 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 8
    Points : 6
    Points
    6
    Par défaut T-SQL equiv de la clause WHERE (col1, col2,)IN(select )
    si une ligne de tab1 existe dans un ens de lignes de tab2 je la supprime
    en oracle c'est:

    delete from tab1
    where ( col1, col2, col2)
    IN ( select col1, col2, col2
    from tab2
    where cond
    );

    quelle est la requête equiv en T-SQL?

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 772
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 772
    Points : 52 735
    Points
    52 735
    Billets dans le blog
    5
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    delete from tab1
    FROM tab1 T1
          INNER JOIN tab2 T2
                ON T1.col1 = T2.col1 AND T1.col2 = T2.col2 AND T1.col3 = T2.col3
    where cond
    Autre solution :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    delete from tab1
    WHERE EXISTS(SELECT * 
                 FROM   tab2 T2
                 WHERE  tab1.col1 = T2.col1 AND tab1.col2 = T2.col2 AND tab1.col3 = T2.col3)
    where  cond


    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. Requête SQL récursive dans la clause WHERE
    Par haykelFST dans le forum Développement
    Réponses: 8
    Dernier message: 12/04/2012, 10h37
  2. Réponses: 0
    Dernier message: 27/07/2009, 15h02
  3. Réponses: 4
    Dernier message: 07/08/2008, 13h31
  4. [t-sql] instruction CASE dans clause WHERE
    Par ignitionflip dans le forum Langage SQL
    Réponses: 4
    Dernier message: 22/01/2007, 18h07
  5. [PL/SQL Oracle] Syntaxe dans clause where
    Par Misdrhaal dans le forum Oracle
    Réponses: 2
    Dernier message: 01/03/2006, 13h33

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