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

Requêtes PostgreSQL Discussion :

Delete et contrainte de clé étrangère


Sujet :

Requêtes PostgreSQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 25
    Points : 11
    Points
    11
    Par défaut Delete et contrainte de clé étrangère
    Bonjour à tous,

    je rencontre un problème pour supprimer certains enregistrements de ma base Posgres car ma requête "viole la contrainte de clé étrangère".

    Je souhaiterais supprimer tous les enregistrements pour lesquels il n'y a pas de clé étrangère à l'aide de la commande delete, et traiter les autres à la main (je ne veux pas supprimer en cascade).

    Existe-il une commande qui permette de faire cela, sachant qu'isoler les enregistrements sans clé étrangère est trop complexe pour moi ?
    Merci d'avance pour vos réponses !

  2. #2
    Membre éprouvé Avatar de Oishiiii
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 508
    Points : 1 104
    Points
    1 104
    Par défaut
    Bonjour,

    Supprimer les lignes pour lesquelles aucune autre ligne d'autre table fait référence n'est pas très compliqué.

    Par exemple avec les deux tables suivantes:
    Pays(p_id, p_nom)
    Ville(v_id, v_nom, p_id#)

    Pour supprimer les pays qui n'ont pas de ville, cela ressemblerai à ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DELETE FROM Pays AS p
    WHERE NOT EXISTS (
      SELECT *
      FROM Ville AS v
      WHERE v.p_id = p.p_id
    );
    Pour la tester avec un SELECT:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT p_id, p_nom
    FROM Pays AS p
    WHERE NOT EXISTS (
      SELECT *
      FROM Ville AS v
      WHERE v.p_id = p.p_id
    );

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 25
    Points : 11
    Points
    11
    Par défaut
    Merci pour votre réponse.

    Malheureusement, dans mon cas c'est tout de même assez compliqué car les clés étrangères peuvent être contenues dans de multiples autres tables

Discussions similaires

  1. Réponses: 2
    Dernier message: 14/08/2008, 09h01
  2. [Débutant ACCESS] Contrainte de clés étrangères
    Par elgringo2007 dans le forum Access
    Réponses: 2
    Dernier message: 12/06/2006, 18h56
  3. Réponses: 5
    Dernier message: 28/04/2006, 11h55
  4. [debutant]delete et contrainte d'integrite
    Par christophebmx dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 02/11/2004, 22h18
  5. Contraintes de clés étrangères non respectées
    Par parfait dans le forum Requêtes
    Réponses: 7
    Dernier message: 28/07/2004, 12h48

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