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

Oracle Discussion :

[SQL]Index Type


Sujet :

Oracle

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    74
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2005
    Messages : 74
    Par défaut [SQL]Index Type
    Bonjour,

    Je souhaite définir des index pour accélérer le temps de traitement sur une table.
    J’ai vu qu'il existe différents type d'index :
    - Unique.
    - Bitmap.
    - BTree.

    Savez vous quelles sont leurs avantages et inconvénients respectifs, en existe t'il d'autres?

    Quelle est la différence entre ces deux cas de figure?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    CREATE INDEX x 
    ON emp (num, nom)
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE INDEX x1 
    ON emp (num);
    CREATE INDEX x2 
    ON emp (nom);
    Une dernière question, ici, je ne spécifie pas le type d'index, quel est celui qui est pris par défaut?

    Merci de vos réponses.

    Stos

  2. #2
    Rédactrice

    Avatar de Fleur-Anne.Blain
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2 636
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 636
    Par défaut
    Bonjour,

    Voici ce que je peux te dire, les deux syntaxes sont bonnes, reste un choix de ta part a faire:

    Un index sur une seule colonne est plus simple et si tu utilises beaucoup cette colonne, c'est ce dont tu as besoin.

    Un index sur plusieurs colonne est en général créer, si je ne me trompe pas, lorsque tu utilise les colonnes de cet index dans les clauses WHERE.
    la culture c'est comme la confiture moins on en a plus on l'étale.

    Mes tutos

  3. #3
    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
    pas forcément, l'index sur les deux colonnes est utile si les requêtes utilisent les 2 colonnes ou la première... en revanche pas si seule la 2° est utilisée. Par ailleurs, même si la 2° colonnes n'est pas utilisée elle peut être utile dans l'index pour faire une requête du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select nom from x where num = ...
    dans ce cas, Oracle utilise l'index sur les 2 colonnes pour trouver la ligne mais aussi pour afficher le nom... en effet, si toutes les colonnes sont dans l'index un TABLE ACCESS n'est pas nécessaire et ça peut faire gagner beaucoup de temps

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    74
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2005
    Messages : 74
    Par défaut
    Merci de vos réponses, je crois que je comprends l'intéret de chacune des deux syntaxes.

    Ariez vous des infos, ou un lien, sur les différents types d'index, leurs particularités??

    Merci

  5. #5
    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
    En anglais dans le Concept Guide:

    http://download-uk.oracle.com/docs/c....htm#sthref893

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    74
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2005
    Messages : 74
    Par défaut
    Merci du renseignement,
    Mon anglais n'est pas au top , mais je vais faire avec.

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

Discussions similaires

  1. ALTER INDEX / Type LOB
    Par segphault dans le forum Oracle
    Réponses: 3
    Dernier message: 09/02/2018, 11h35
  2. [SQL] indexation textuelle
    Par bomber dans le forum Langage SQL
    Réponses: 3
    Dernier message: 04/01/2007, 14h20
  3. convertir un type sql en type java
    Par lilli1407 dans le forum JDBC
    Réponses: 3
    Dernier message: 15/11/2006, 15h50
  4. requete SQL sur Typed DataSet, sans utiliser SQL serveur
    Par Harry_polin dans le forum Accès aux données
    Réponses: 2
    Dernier message: 06/10/2006, 19h15
  5. [Sql] index sur vue
    Par fxp17 dans le forum Oracle
    Réponses: 8
    Dernier message: 23/02/2006, 10h56

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