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 :

Définition de sélectivité et cardinalité


Sujet :

Administration Oracle

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    461
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 461
    Points : 283
    Points
    283
    Par défaut Définition de sélectivité et cardinalité
    Bonjour,
    Je souhaite avoir une définition exacte de la sélectivité et la cardinalité, car j'ai du mal à voir la différence en suivant celles fournies par Oracle :
    Selectivity : The first measure, selectivity, represents a fraction of rows from a row set.
    The row set can be a base table, a view, or the result of a join or a GROUP BY operator.

    Cardinality : Cardinality represents the number of rows in a row set. Here, the row set
    can be a base table, a view, or the result of a join or GROUP BY operator.
    Pour la Sélectivité, je pense avoir compris que c'est le ratio suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select count(*) from Mon_Objet where col = 'value' / select count(*) from Mon_Objet
    Par contre, pour la Cardinalité, j'avoue avoir du mal.
    Si vous aviez un exemple concret, ça m'aiderait bien.

    Merci d'avance.

  2. #2
    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
    Points : 3 597
    Points
    3 597
    Par défaut
    La cardinalité c'est tout simplement le nombre de lignes d'un ensemble de lignes qui peut être le résultat d'une requête ou une étape intermédiaire d'un plan d'exécution d'une requête. La sélectivité est donc un rapport de cardinalités.

    Dans votre exemple, c'est:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT count(*) FROM Mon_Objet WHERE col = 'value'
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT count(*) FROM Mon_Objet

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    461
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 461
    Points : 283
    Points
    283
    Par défaut
    Merci Pierre, donc pour la sélectivité, si
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT count(*) FROM Mon_Objet WHERE col = 'value'
    renvoie 10 lignes
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT count(*) FROM Mon_Objet
    renvoie 100 lignes
    La sélectivité est de Pour la cardinalité, c'est donc 10 ?

    Merci pour votre aide.

  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
    Points : 3 597
    Points
    3 597
    Par défaut
    Vous pouvez trouver une définition qui lie sélectivité et cardinalité dans Troubleshooting Oracle Performance page 13 (lisible sur Google Books):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cardinalité = sélectivité * num_rows
    num_rows est le nombre de lignes traitées en entrée, cardinalité est le nombre de lignes en sortie, ceci pour une opération donnée.

    Dans votre exemple l'opération est accès à une table avec un filtre WHERE col='value', num_rows=100 et sélectivité = 0,10 donc cardinalité = 10.

    Voir aussi
    http://asktom.oracle.com/pls/asktom/...40230704959128

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    461
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 461
    Points : 283
    Points
    283
    Par défaut
    Merci Pierre.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 29/07/2003, 12h52
  2. [Sybase] Définition des symboles
    Par SoaB dans le forum Sybase
    Réponses: 5
    Dernier message: 19/03/2003, 23h06
  3. Cardinalités
    Par Pingwin dans le forum Diagrammes de Classes
    Réponses: 6
    Dernier message: 30/01/2003, 18h22
  4. Définition de "Métalangage"
    Par No dans le forum Langages de programmation
    Réponses: 5
    Dernier message: 19/07/2002, 14h05

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