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

 Oracle Discussion :

delete from table1 where rien dans table2


Sujet :

Oracle

  1. #1
    Inscrit
    Inscrit en
    Février 2006
    Messages
    93
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 93
    Points : 96
    Points
    96
    Par défaut delete from table1 where rien dans table2
    Bonjour,

    J'ai un problème technique avec Oracle.
    J'ai 2 tables: "projet" et "etape"... Un projet est composé de 1 à n étapes. Il peut aussi y avoir des projets sans aucune étape associée mais je souhaite les supprimer.

    Du coup j'ai écrit cela:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    DELETE FROM Projet
    WHERE idprojet not in (select projetid from etape)

    Malheureusement, au lancement de la requête j'ai le message suivant:
    0 lignes supprimé

    or j'ai un projet sans aucune étape associée donc il aurait dû me le supprimer...

    Si quelqu'un a une explication, je suis preneur...

  2. #2
    Membre confirmé

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    507
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 507
    Points : 503
    Points
    503
    Par défaut
    Etonnant que cela ne fonctionne pas.

    Une autre solution:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    DELETE FROM projet p
          WHERE NOT EXISTS (SELECT 1
                              FROM etape e
                             WHERE e.projetid = p.idprojet);

  3. #3
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    projectid peut-il être NULL ?

  4. #4
    Inscrit
    Inscrit en
    Février 2006
    Messages
    93
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 93
    Points : 96
    Points
    96
    Par défaut
    Vous avez tous les 2 raison
    La solution de Goldoz efface mon occurence de projet n'ayant pas d'étape liée.
    Et projetid ne pouvait pas être null. J'ai modifié ce paramètre en donnant la possibilité d'être null et du coup ça fonctionne.
    Merci à vous 2!

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

Discussions similaires

  1. [Débutant] delete from table1 left join table2
    Par djelloharmel dans le forum VB.NET
    Réponses: 5
    Dernier message: 30/11/2011, 10h17
  2. Réponses: 2
    Dernier message: 08/03/2011, 09h26
  3. Requete: Delete from T where Not In
    Par jamesleouf dans le forum Langage SQL
    Réponses: 2
    Dernier message: 23/05/2008, 09h15
  4. Réponses: 4
    Dernier message: 26/04/2006, 10h09
  5. DELETE FROM t where t.id IN (SELECT id FROM t....)
    Par davcha dans le forum Langage SQL
    Réponses: 4
    Dernier message: 05/01/2006, 15h19

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