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 MySQL Discussion :

Requête sur VIEW ou TABLE = perfs identiques ?


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    84
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 84
    Par défaut Requête sur VIEW ou TABLE = perfs identiques ?
    Bonsoir à tous,

    J'ai détecté une requête dans mon appli qui dure 8s.

    J'en ai faite une VIEW en espérant gagner quelques secondes. J'avais en effet lu à quelques endroits que les VIEW étaient en quelque sorte "précompilées" et s'exécutaient beaucoup plus rapidement que des SELECT classiques.

    Que nenni, les deux requêtes SELECT classique ou SELECT view ont un temps d'exécution sensiblement identique.

    L'intérêt des VIEWS réside-t-il donc "seulement" dans une facilitation de la syntaxe SQL ? 0 intérêt utilisateur ? (ie : performances)

    Précision, je suis sous MYSQL 5.0

    Merci d'avance pour vos réponses,

    Amon.

  2. #2
    Membre émérite 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 : 37
    Localisation : France, Ain (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2009
    Messages : 508
    Par défaut
    Bonsoir,

    Une requête sur une vue n'est pas plus performante que sa requête SELECT de création.
    Une vue n'est qu'un "alias" sur une requête SELECT.
    Mais elles ont d'autres fonctions très importantes (vue externe, simplification des requêtes, gestion de privilèges), voir par exemple ce sujet pour plus d'infos:
    http://www.developpez.net/forums/d91...e/#post5161803

    Pour le coté performance, il faut utiliser des vues matérialisées, qui elles voient leurs données stockées physiquement sur le disque.

    MySQL ne propose pas les vues matérialisées.
    Il est peut-être possible de les simuler en créant une table alimentée par des Triggers.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    84
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 84
    Par défaut
    Merci Oishiiii pour ta réponse claire et ces pistes de réflexion.
    Bonne soirée !

  4. #4
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Pour améliorer la performance de ta requête, commence par vérifier que la ou les tables impliquées soient bien indexées.

    Si ce n'est pas trop tard, vérifie aussi les types des colonnes et le schéma de la BDD.

    Les premières optimisations commencent par là.

    Si tu nous donnes la requête et la structure des tables, on peut t'y aider.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 29/09/2009, 01h50
  2. Réponses: 7
    Dernier message: 05/06/2008, 14h54
  3. Réponses: 3
    Dernier message: 14/03/2007, 18h31
  4. Réponses: 4
    Dernier message: 06/09/2006, 15h04
  5. sous-requête sur 1 seule table
    Par By-nôm dans le forum Access
    Réponses: 5
    Dernier message: 02/08/2006, 16h13

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