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

Administration MySQL Discussion :

Clé étrangère peut optimizer le serveur sql ?


Sujet :

Administration MySQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    novembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : novembre 2020
    Messages : 15
    Points : 17
    Points
    17
    Par défaut Clé étrangère peut optimizer le serveur sql ?
    bonjour a tout le mondes ,
    j'ai actuellement une bdd en myisam et je compte passer en innodb du coup j'aimerai savoir si je passe en innodb et ce que je gagnerait du temps si j'ajoute des FK(Clé étrangère ) alors que j'ai des des tables index ?

    merci d'avance

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    août 2008
    Messages
    2 888
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : août 2008
    Messages : 2 888
    Points : 5 690
    Points
    5 690
    Par défaut
    L'objectif des clé étrangères (donc des contraintes) n'est pas d'améliorer la performance mais d'améliorer la qualité des données, donc de base je dirais non.

    Par contre, les clés étrangères sont également de l'information utilisable par l'optimiseur qui peuvent conduire à des amélioration de performance, plus sur des SELECT que sur des INSERT.
    Par ailleurs, être performant, mais avec des données de mauvaises qualités, n'a pas forcément grand intérêt, particulièrement sur une application de gestion.

    Pour résumer, je dirais que les contraintes sont NÉCESSAIRES pour la qualité des données, la performance n'étant pas leur objectif premier.

    PS : un exercice intéressant est effectivement de créer les contraintes et de voir si elles peuvent s'activer avec les données existantes, le résultat pouvant être décevant...

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    novembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : novembre 2020
    Messages : 15
    Points : 17
    Points
    17
    Par défaut
    Merci skuatamad pour ta réponse je vais faire l'exercice que tu me conseille .

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    mars 2010
    Messages
    7 282
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : mars 2010
    Messages : 7 282
    Points : 23 292
    Points
    23 292
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    Citation Envoyé par skuatamad Voir le message
    Par contre, les clés étrangères sont également de l'information utilisable par l'optimiseur qui peuvent conduire à des amélioration de performance, plus sur des SELECT que sur des INSERT.
    Je ne crois pas que MySQL ait implémenté l'optimisation sémantique, malheureusement, du coup pas de gain en performance à attendre.
    Cela étant, c'est bien l'intégrité des données qui est la raison d'être des FK, rien que pour cette raison, il est indispensable de les utiliser

Discussions similaires

  1. [AC-2003] Est-ce qu'une clé étrangère peut être vide ou nulle?
    Par js8bleu dans le forum Modélisation
    Réponses: 2
    Dernier message: 07/12/2009, 11h21
  2. Tomcat peut-il être Serveur de sockets non HTTP ?
    Par yannlejunter dans le forum Tomcat et TomEE
    Réponses: 5
    Dernier message: 03/06/2009, 18h04
  3. Réponses: 1
    Dernier message: 24/12/2007, 13h15
  4. Réponses: 2
    Dernier message: 13/06/2007, 11h22
  5. Ubuntu ne peut pas démarrer serveur X
    Par Invité4 dans le forum Applications et environnements graphiques
    Réponses: 8
    Dernier message: 02/07/2005, 15h57

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