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

Optimisations SGBD Discussion :

Meilleures performances : Clés étrangères ou références table principale ?


Sujet :

Optimisations SGBD

  1. #1
    Membre extrêmement actif Avatar de cortex024
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 301
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 301
    Points : 1 119
    Points
    1 119
    Par défaut Meilleures performances : Clés étrangères ou références table principale ?
    Bonjour,

    je vais avoir une table principale de personnes, qui sera reliée a pas mal d'autres tables, en guise de "details".

    je me demandais si il valait mieux niveau performance, évolutivité, conception, mettre des clés étrangères sur ma table principale, ou si il valait mieux ne pas en mettre, et référer dans toutes mes tables détails avec un champ indiquant à quelle personne ce détail appartient.

    Les clés étrangères dans la première table pourrait faciliter la programmation, mais la seconde possibilité permettrait une évolutivité facile sans modification de table.

  2. #2
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 903
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 903
    Points : 6 027
    Points
    6 027
    Par défaut
    Citation Envoyé par cortex024
    Bonjour,

    je vais avoir une table principale de personnes, qui sera reliée a pas mal d'autres tables, en guise de "details".

    je me demandais si il valait mieux niveau performance, évolutivité, conception, mettre des clés étrangères sur ma table principale, ou si il valait mieux ne pas en mettre, et référer dans toutes mes tables détails avec un champ indiquant à quelle personne ce détail appartient.

    Les clés étrangères dans la première table pourrait faciliter la programmation, mais la seconde possibilité permettrait une évolutivité facile sans modification de table.
    Sans aucun doute, l'utilisation de FK est largement préférable et recommandée.
    D'ailleurs, elles servent à ça

    De plus, tu parles d'évolution facile et sans FK, ce sera tout sauf facile. Si tu fais l'impasse sur les FK, ce sera par programmation que devront être gérées toutes les dépendances fonctionnelles, et naturellement, si tu ajoutes 1 table, c'est tout un pavé de contrôles qu'il faudra intégrer à l'appli.

    Allez, je te le fais à un bon prix une FK non mise en place doit peser entre 20 et 40 lignes de code (selon le langage).

    A toi de voir...

    Enfin, un modèle complet (avec les FK donc) permet la retro-conception, ce qui facilite l'appropriation de l'appli, et donc sa maintenance. Coté technique, un bon DBA pourra tuner plus finement la base.
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  3. #3
    Expert éminent sénior
    Avatar de fsmrel
    Homme Profil pro
    Spécialiste en bases de données
    Inscrit en
    Septembre 2006
    Messages
    8 002
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Spécialiste en bases de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2006
    Messages : 8 002
    Points : 30 905
    Points
    30 905
    Billets dans le blog
    16
    Par défaut
    Pour compléter ce que vous a dit Qi130, je rappelle que les clés étrangères sont là pour garantir l’intégrité référentielle.

    Imaginez que les personnes sont des clients qui achètent des voitures à crédit ou qui prennent des contrats d’assurance-vie, ou que sais-je encore et donc qu’il faille mettre en œuvre une table Contrat dont les lignes ont une durée de vie certaine. Grâce aux clés étrangères, vous êtes sûr qu’en face d’un contrat il y aura toujours un client : si vous supprimez un client, soit le système le refusera parce que l’utilisateur aura défini une règle de gestion selon laquelle on ne supprime pas un client qui a un contrat (ce que vous avez traduit au niveau de la base de données par une clause Restrict ou No Action pour la clé étrangère) ou bien, la suppression sera acceptée parce que selon la règle de gestion, la suppression d’un client entraîne celle de ses contrats (clause Cascade).

    Avec les clés étrangères :

    1) l’intégrité de votre système est garantie par le SGBD

    Si vous n’en voulez pas, vous prenez en charge vous-même l’intégrité par vos programmes et vous risquez tout simplement de vous retrouver un jour avec des milliers de contrats actifs mais pour lesquels il n’y a plus de clients en face. Je dis cela pour l’avoir observé chez mes propres clients : au départ tout va bien, mais avec le temps, comptez 30% de contrats orphelins.

    2) vous sous-traitez des règles de gestion au SGBD

    A défaut, ça sera à vous aurez de programmer ces règles, comme vous le dites :
    Les clés étrangères dans la première table pourrait faciliter la programmation
    Quand vous écrivez
    la seconde possibilité permettrait une évolutivité facile sans modification de table
    Je ne vois pas en quoi la mise en œuvre d’une contrainte "Foreign key" gêne l’évolutivité. Vous pouvez pour une raison ou une autre débrancher cette contrainte, pour la rebrancher avant de remettre les tables à la disposition des applications.

    Un conseil : par référence aux trois petits cochons, préférez construire une maison en briques plutôt qu’en paille et implantez l’intégrité référentielle. Attention au loup.
    (a) Faites simple, mais pas plus simple ! (A. Einstein)
    (b) Certes, E=mc², mais si on discute un peu, on peut l’avoir pour beaucoup moins cher... (G. Lacroix, « Les Euphorismes de Grégoire »)
    => La relativité n'existerait donc que relativement aux relativistes (Jean Eisenstaedt, « Einstein et la relativité générale »)

    __________________________________
    Bases de données relationnelles et normalisation : de la première à la sixième forme normale
    Modéliser les données avec MySQL Workbench
    Je ne réponds pas aux questions techniques par MP. Les forums sont là pour ça.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 13/08/2014, 13h00
  2. Réponses: 4
    Dernier message: 13/08/2009, 18h47
  3. insertion de clés étrangères dans ma table
    Par narama87 dans le forum Requêtes
    Réponses: 1
    Dernier message: 28/04/2009, 13h51
  4. 2 Clés étrangères sur une table
    Par adel53 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/11/2008, 13h55
  5. Réponses: 6
    Dernier message: 08/11/2008, 15h37

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