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

Quand créer des index ?


Sujet :

Administration Oracle

  1. #1
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut Quand créer des index ?
    Bonsoir,
    quand est ce est jugé necessaire de créer des index ?
    parce que là , j'ai une table susceptible de contenir des millions de lignes .
    déjà j'ai lu quelques part que oracle crée automatiquement un index sur le key de la table , dans ce cas dois je en créer un autre sur une clé étrangère de la table ?

  2. #2
    Membre averti
    Inscrit en
    Mars 2008
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 35
    Par défaut
    pour les colonne utilisés dans des jointures, clauses where...
    il faut aussi se poser la question de quel type d'index mettre??

  3. #3
    Expert confirmé Avatar de frp31
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juillet 2006
    Messages
    5 196
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juillet 2006
    Messages : 5 196
    Par défaut
    surtout eviter d'indexer des colonnes pouvant contenir des doublons

  4. #4
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    Citation Envoyé par zaineb.z Voir le message
    Bonsoir,
    dans ce cas dois je en créer un autre sur une clé étrangère de la table ?
    En général il est recommandé de créer des index sur les clés étrangères au moins pour des raisons de concurrence d'accès.

    Citation Envoyé par frp31 Voir le message
    surtout eviter d'indexer des colonnes pouvant contenir des doublons
    Pourquoi une règle aussi générale ?

  5. #5
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    type d'index je croyais qu'il y a qu'un seul type d'index

  6. #6
    Membre émérite Avatar de 13thFloor
    Homme Profil pro
    DBA Oracle freelance
    Inscrit en
    Janvier 2005
    Messages
    670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France

    Informations professionnelles :
    Activité : DBA Oracle freelance

    Informations forums :
    Inscription : Janvier 2005
    Messages : 670
    Par défaut
    Citation Envoyé par zaineb.z Voir le message
    type d'index je croyais qu'il y a un seul type d'index
    btree (par défaut), bitmap, reverse, descending, fbi... tu as le choix.

    En réponse à ta question initiale, je dirai :
    - quand le coût de recherche d'informations est meilleur (moins de blocs à parcourir que pour lire totalement une table)
    - pour garantir l'intégrité des données (index unique ou primaire)

  7. #7
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    Donc , pour remédier à mon problème ( recherche plus rapide ... ) je dois créer un index sur les clés étrangères ou non? vous me conseillez quel type d'index ?
    et merci tous de m'avoir repondue

  8. #8
    Membre averti
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Par défaut
    je te conseille de lire ce cours il parle des diiférents types d'index:

    http://duongkhang.free.fr/Wika/wikka...OptimisationBD

  9. #9
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    Merci
    j'hesite entre le type bitmap et b-tree , lequel entre les deux dois je opter pour ?

  10. #10
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    bitmap n'est à utiliser que dans des cas exceptionnelles : très forte volumétrie, valeurs de colonne fixe (sexe, oui/non, etc...) et peu de mise à jour de l'index.

    Voici des articles intéressant sur l'optimisation :
    OPTIMISATION des SGBDR et du SQL
    Intéret des indexes par l'exemple et Optimiser SQL Server (sous SQL Server mais c'est la méthode qui est importante)

  11. #11
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    Merci j'ai lu le cours, c'est très intéressant sauf que... je n'arrive pas à me décider.
    j'ai même fait une recherche dans le forum , c'est très ambigu ce que j'ai trouvé
    ce que j'ai compris c'est que si j'ajoute un index à ma table , je dois le faire sur les clés étrangères et cela,d'après ce que j'ai lu, n'est pas toujours très "optimisant" lors des recherches ( select , insert en lot )
    je ne sais plus quoi faire....

  12. #12
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Bah il y a un moment où la prévision de l'avenir a ses limites... donc sauf si est doué de don de voyance, je ne peux que t'encourager à tester les indexes que tu penses être intéressant. Enfin, sur une FK c'est rarement inutile

  13. #13
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    D4acc , donc un b tree sur les pk , à chaque pk un index c'est bien cela ?

  14. #14
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    oui, JAMAIS de bitmap sur une PK. Et PK = contrainte unique + index

  15. #15
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    dans ma table , il y a un seul pk , j'ai lu quelques part que oracle crée un index automatiquement avec le pk ,
    donc , si je veux réduire le temps d'exécution des requêtes , dois je créer un index sur les champs les plus sollicités dans mes requêtes ?

  16. #16
    Membre émérite Avatar de 13thFloor
    Homme Profil pro
    DBA Oracle freelance
    Inscrit en
    Janvier 2005
    Messages
    670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France

    Informations professionnelles :
    Activité : DBA Oracle freelance

    Informations forums :
    Inscription : Janvier 2005
    Messages : 670
    Par défaut
    Citation Envoyé par zaineb.z Voir le message
    dans ma table , il y a un seul pk , j'ai lu quelques part que oracle crée un index automatiquement avec le pk ,
    donc , si je veux réduire le temps d'exécution des requêtes , dois je créer un index sur les champs les plus sollicités dans mes requêtes ?
    Oui et non.
    Oui si le parcours par index est moins couteux que lire toute la table.
    Oui si la proportion de données à ramener est faible (moins de 15%).
    Dans le doute, un histogramme sur les colonnes indexées aidera l'optimiseur à choisir entre un parcours par index ou un parcours de la table.
    Oui si le nombre de blocs occupés par la table est significatif.

    Attention : trop d'index nuit aux perfs lors des mises à jours.
    Attention (bis) aux paramètres optimizer_index_cost_adj et db_file_multiblock_read_count qui ont un impact sur la prise en compte des index.

  17. #17
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Citation Envoyé par 13thFloor Voir le message
    Attention (bis) aux paramètres optimizer_index_cost_adj et db_file_multiblock_read_count qui ont un impact sur la prise en compte des index.
    NON ! Je voudrais qu'on arrête de parler de ces paramètres qui sont extrêmement délicat à utiliser et en général, quand on en est à toucher à ça, c'est qu'il y a un autre problème.

    Il vaut mieux avant toute chose se concentrer sur les stats.

    Pour répondre à zaineb.z, en général on indexe les colonnes filtrantes (dans le WHERE) en tenant compte de la sélectivité des données. Les liens que j'ai donné expliquent tout ça.

  18. #18
    Membre émérite Avatar de 13thFloor
    Homme Profil pro
    DBA Oracle freelance
    Inscrit en
    Janvier 2005
    Messages
    670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France

    Informations professionnelles :
    Activité : DBA Oracle freelance

    Informations forums :
    Inscription : Janvier 2005
    Messages : 670
    Par défaut
    Citation Envoyé par orafrance
    NON ! Je voudrais qu'on arrête de parler de ces paramètres qui sont extrêmement délicat à utiliser et en général, quand on en est à toucher à ça, c'est qu'il y a un autre problème.
    C'est juste une mise en garde concernant les possibilités de favoriser ou non l'utilisation des index, pas une préconisation.
    Juste pour lui indiquer que les stats ne sont pas les seules éléments qui déterminent si un index est utilisé ou non.

  19. #19
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Sauf qu'il n'y a pas à y faire attention... en plus, on a à faire visiblement à un débutant et c'est dommage de l'embrouiller avec des paramètres qu'on ne doit pas toucher.

  20. #20
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Par défaut
    merci de m'avoir repondu ,
    orafrance , tu as raison , quand j'ai lu
    optimizer_index_cost_adj et db_file_multiblock_read_count
    j'ai
    merci à tous encore et bonne soirée

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/01/2015, 00h55
  2. Quand Créer un index
    Par LBO72 dans le forum Administration
    Réponses: 9
    Dernier message: 27/10/2009, 16h33
  3. Quand créer les index ?
    Par WebPac dans le forum Optimisations
    Réponses: 13
    Dernier message: 13/03/2009, 17h13
  4. Quand créer un index..
    Par thibouille dans le forum Modélisation
    Réponses: 1
    Dernier message: 02/11/2007, 17h04
  5. pb pour créer des index [too many keys]
    Par Issam dans le forum Débuter
    Réponses: 3
    Dernier message: 19/01/2005, 20h58

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