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

MS SQL Server Discussion :

[Index]Problème de performance


Sujet :

MS SQL Server

  1. #1
    Membre éclairé Avatar de Le Pharaon
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    880
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 880
    Points : 742
    Points
    742
    Par défaut [Index]Problème de performance
    Salut à tous
    J'ai créé des index sur une table fréquemment sollicitée qui fait souvent objet d'insertion et de mise à jour mais à ma grande surprise la performance des requêtes reste telle qu'elle était.

    Est ce q'il y'a d'autres moyens pour pallier cette insuffisance ?

    Merci

  2. #2
    Expert confirmé
    Avatar de rudib
    Homme Profil pro
    Fakir SQL Server & NoSQL
    Inscrit en
    Mai 2006
    Messages
    2 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Fakir SQL Server & NoSQL

    Informations forums :
    Inscription : Mai 2006
    Messages : 2 573
    Points : 4 043
    Points
    4 043
    Par défaut
    Bonjour,

    Regarde tes plans d'exécution pour voir si les index sont utilisés.

    Quelques éléments pour t'aider à optimiser tes requêtes ici : http://rudi.developpez.com/sqlserver.../optimisation/

  3. #3
    Invité
    Invité(e)
    Par défaut
    Exécuter un trace avec le profiler.
    Analyser le plan d'exécution de la requête.
    Optimiser le code de la requête (peut-être).
    Adapter le fillfactor de ton index.
    Se poser la question de savoir si les bons champs ont été indexés.
    Savoir s'il n'y a pas trop d'index.
    etc...

  4. #4
    Membre éclairé Avatar de Le Pharaon
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    880
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 880
    Points : 742
    Points
    742
    Par défaut
    Merci à vous tous

    Est ce que c'est nécessaire d'indexer une vue dont les tables sous-jacentes contiennent déjà des index ?

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 850
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 850
    Points : 52 984
    Points
    52 984
    Billets dans le blog
    6
    Par défaut
    tout dépend. Si la vue contient des calculs d'agrégat, en d'autres termes si les données finales de la vue sont en très faible quantité par rapport aux tables d'origine, cette technique est payante.

    A +

  6. #6
    Membre éclairé Avatar de Le Pharaon
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    880
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 880
    Points : 742
    Points
    742
    Par défaut
    Merci SqlPro
    Je me suis maintenant mis à la création de ma première vue indexée et ça trébuche quelque part.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CREATE VIEW SV_Veille WITH SCHEMABINDING AS
     
    SELECT     idVehicule, DatePrise, MAX(heureprise) AS HeureMax, 
                   SUM (Quantite) AS Quantite
    FROM          T_PriseCarburant
     
    GROUP BY idVehicule, DatePrise
     
    GO 
     
    CREATE UNIQUE CLUSTERED INDEX  idPrise ON SV_Veille(idVehicule,DatePrise)
    Voici le message d'erreur que j'ai reçu :

    Impossible de lier le schéma vue 'SV_Veille' car le nom 'T_PriseCarburant'
    n'est pas valide pour la liaison de schéma. Les noms
    doivent être en deux parties et un objet ne peut pas avoir de référence
    circulaire.

  7. #7
    Membre éclairé Avatar de Le Pharaon
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    880
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 880
    Points : 742
    Points
    742
    Par défaut
    ça marche j'avais oublié de faire précèder le nom de la table par dbo

Discussions similaires

  1. Problèmes de performance - Index
    Par cyril68 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 16/03/2006, 14h25
  2. [jeu]problème de performance d'un algo
    Par le Daoud dans le forum Algorithmes et structures de données
    Réponses: 12
    Dernier message: 30/05/2005, 16h07
  3. [C#] Probléme de performance avec IsDbNull
    Par jab dans le forum Windows Forms
    Réponses: 8
    Dernier message: 04/04/2005, 11h39
  4. [oracle 9i][Workbench]Problème de performance
    Par nuke_y dans le forum Oracle
    Réponses: 6
    Dernier message: 03/02/2005, 17h38
  5. [ POSTGRESQL ] Problème de performance
    Par Djouls64 dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 26/05/2003, 16h18

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