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 :

Supression dans une table sauf pour certaine valeurs


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    153
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2009
    Messages : 153
    Points : 37
    Points
    37
    Par défaut Supression dans une table sauf pour certaine valeurs
    Je tente de faire un :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DELETE FROM X WHERE (SELECT ID IS NOT IN (1,2,3,4,5))
    Est ce que je raisonne mal et sinon comment faire ?

    En gros mon but c'est de supprimer toute ma table sauf les valeur pour ID = 1 ou 2 ou 3 ou 4 ou 5

    essayé aussi en faisant

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DELETE FROM X WHERE ID = (SELECT IS NOT IN (1,2,3,4,5))
    ....... je ne comprends pas vraiment

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    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 102
    Points : 28 401
    Points
    28 401
    Par défaut
    Je suppose que c'est cela que tu cherches à faire...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DELETE FROM X WHERE ID NOT IN (1, 2, 3, 4, 5)
    Je t'encourage à aller (re)lire les cours SQL

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    153
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2009
    Messages : 153
    Points : 37
    Points
    37
    Par défaut
    Yes, c'est en cours je monte doucement en faisant des tests pour comprendre les choses...
    Le problème c'est que cette commande prend elle en compte le fait que l'ID est vide ?
    ID=NULL
    Car sur 200k lignes, pas une n'est supprimées alors que j'ai la moitié avec ID= 1 ou 2 3 4 5

    (je veux bien garder les lignes avec ces ID et supprimer TOUT le reste)

    la requete me renvoie 0 modifications

    merci encore pour ton aide

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    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 102
    Points : 28 401
    Points
    28 401
    Par défaut
    NULL est un cas à part qui n'est égal à rien, même pas à lui-même.
    Il faut que tu précises que tu veux aussi supprimer les lignes dont la colonne ID n'est pas renseignée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    DELETE FROM X 
    WHERE   ID NOT IN (1, 2, 3, 4, 5)
        OR  ID IS NULL
    ;

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    153
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2009
    Messages : 153
    Points : 37
    Points
    37
    Par défaut
    merci

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 01/10/2014, 17h34
  2. Réponses: 2
    Dernier message: 07/11/2013, 15h21
  3. MAJ dans une table conditionnée par la valeur d'un de ses champs
    Par NicolasTT dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 24/03/2011, 15h31
  4. Réponses: 2
    Dernier message: 25/06/2008, 14h58
  5. Réponses: 5
    Dernier message: 02/05/2008, 14h46

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