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

PostgreSQL Discussion :

Héritage postgresql (problème d'unicité)


Sujet :

PostgreSQL

  1. #1
    Membre régulier Avatar de zakimadrid
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2012
    Messages : 76
    Points : 75
    Points
    75
    Par défaut Héritage postgresql (problème d'unicité)
    tout d'abord bonjour à toutes et à tous,

    pour vous citer le problème, j'ai une table mère Personne et 2 tables filles Médecin et Patient.

    Quand j'ajoute 2 entrées avec le même id dans les deux tables filles sont propagées à la table mère alors que "idPer" est un champ clé primaire dans la table mère.

    donc vous comprenez le problème j'ai deux entrées dans la table mère avec le meme idPer et le SGBD n'intervient pas.

    a prendre en compte que je travail sur Postgresql.

    de l'aide s'il vous plait et merci.
    Vaut mieux poser une question et passer pour bête que le rester toute une vie

  2. #2
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Points : 18 679
    Points
    18 679
    Par défaut
    Les contraintes ne seront pas partagées... seule la structure est héritée
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  3. #3
    Membre régulier Avatar de zakimadrid
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2012
    Messages : 76
    Points : 75
    Points
    75
    Par défaut
    je sais que les contrainte ne sont pas hérités.
    est ce c'est logique d'avoir plusieurs entrées avec les mêmes valeurs du champ "idPer" dans la table mère Personne alors que ce dernier champ est une clé primaire?
    Vaut mieux poser une question et passer pour bête que le rester toute une vie

  4. #4
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Bonjour,


    non c'est pas logique.

    Prenons un héritage simple, uen table mere et deux tables filles.

    Niveau ddl ca donnera ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    create table t_mere (id serial primary key);
    create table t_fille1 (id int primary key references t_mere(id));
    create table t_fille2 (id int primary key references t_mere(id));
    Quand vous faites une insertion, il faut d'abord générer la ligne dans la table mere puis insérer les valeurs souhaitez dans la/les tables filles (vu qu'un medecin peut aussi etre un patient, il n'y a pas d'exclusion dans l'héritage)

  5. #5
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    L'explication est là dans la partie "Restrictions".
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  6. #6
    Membre régulier Avatar de zakimadrid
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2012
    Messages : 76
    Points : 75
    Points
    75
    Par défaut
    merci pour votre aide les gars
    Vaut mieux poser une question et passer pour bête que le rester toute une vie

  7. #7
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    Citation Envoyé par zakimadrid Voir le message
    je sais que les contrainte ne sont pas hérités.
    est ce c'est logique d'avoir plusieurs entrées avec les mêmes valeurs du champ "idPer" dans la table mère Personne alors que ce dernier champ est une clé primaire?
    Quand on fait un SELECT dans une table parente, il va aussi afficher les lignes des tables héritées.
    Il n'y a pas de violation d'unicité dans la table parente, car les idPer en doublon n'est pas le contenu de la table parente.

    Voir une autre discussion à ce sujet:

    http://www.developpez.net/forums/d95...ritage-tables/

  8. #8
    Membre régulier Avatar de zakimadrid
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2012
    Messages : 76
    Points : 75
    Points
    75
    Par défaut
    Citation Envoyé par estofilo Voir le message
    Quand on fait un SELECT dans une table parente, il va aussi afficher les lignes des tables héritées.
    Il n'y a pas de violation d'unicité dans la table parente, car les idPer en doublon n'est pas le contenu de la table parente.

    Voir une autre discussion à ce sujet:

    http://www.developpez.net/forums/d95...ritage-tables/
    Merci pour l'information
    Vaut mieux poser une question et passer pour bête que le rester toute une vie

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

Discussions similaires

  1. Héritage : petit problème
    Par Fy_Hertz dans le forum C++
    Réponses: 20
    Dernier message: 31/01/2006, 08h39
  2. [REFERENCES/FOREIGN KEY]problème d'unicité de clé
    Par Guigui_ dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 18/01/2005, 16h47
  3. [Postgresql]Problème avec les fonctions ...
    Par fet dans le forum Requêtes
    Réponses: 4
    Dernier message: 02/10/2003, 09h04
  4. [ POSTGRESQL ] Problème de performance
    Par Djouls64 dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 26/05/2003, 16h18
  5. [PostgreSql] Problème de cadreage de char !!!
    Par moipastoi dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/05/2003, 18h01

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