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 :

Astuce de partitionnement ?


Sujet :

Oracle

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Février 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2005
    Messages : 9
    Par défaut Astuce de partitionnement ?
    Bonjour,

    J’ai une table table1 (champ1, champ2, champ3, champ4)
    Le champ2 de type varchar(2) contienne presque 50% des valeurs nulles.

    Ma question est : est que il y’a un moyen de partitionnées la table table1 en "deux partitions" : la première partition contienne les enregistrements ou les valeurs de champ2 est no nulles, et la deuxième contienne le reste des enregistrements

    NB : base de données : Oracle 10g

    Merci pour votre reponse

  2. #2
    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
    c'est possible mais j'ai du mal à y trouver un quelconque intérêt

  3. #3
    Membre Expert
    Avatar de LeoAnderson
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    2 938
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 2 938
    Par défaut
    Citation Envoyé par orafrance Voir le message
    c'est possible mais j'ai du mal à y trouver un quelconque intérêt
    je suis même pas sûr que ce soit possible !

    RANGE : non car il n'est pas possible de définir l'interval "inférieur à NULL" ou "SUPERIEUR à NULL"
    LIST : non plus, car il n'est pas possible de construire la liste
    HASH : Non plus

  4. #4
    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

  5. #5
    Membre Expert
    Avatar de LeoAnderson
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    2 938
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 2 938
    Par défaut
    Citation Envoyé par orafrance Voir le message
    je pensais pas à NULL mais aux milliards d'autres valeurs que peut prendre le champ !
    j'avais juste oublié "DEFAULT"...

    mais l'intérêt me semble tout de même incertain....

  6. #6
    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 LeoAnderson Voir le message
    mais l'intérêt me semble tout de même incertain....
    on est d'accord

  7. #7
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

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

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    dans range, les valeurs nulles vont dans maxvalue

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    SQL> create table table1(champ1 number, champ2 char(2), champ3 number, 
    champ4 number) partition by range(champ2)  (
    partition p1 values less than ('ÿÿ'), partition p2 values less than (maxvalue));
    Table created.
    SQL> insert into table1(champ2) values ('x');                           
    1 row created.
    SQL> insert into table1(champ2) values (null);                          
    1 row created.
    SQL> select * from table1 partition (p1);                               
        CHAMP1 CH     CHAMP3     CHAMP4
    ---------- -- ---------- ----------
               x
    SQL> select * from table1 partition (p2);                               
        CHAMP1 CH     CHAMP3     CHAMP4
    ---------- -- ---------- ----------
    bon, deux partitions c'est peu, tu ne voudrais pas partitioner par hash(champ1,champ2) par exemple?

  8. #8
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

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

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    ou alors partition by list avec NULL et DEFAULT et subpartitioning by hash(primary key) par exemple
    [edit]
    quoi que si ton but est d'avoir deux partitions, LIST partitioning comme mentionné ci-dessus semble tenir la route

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Février 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2005
    Messages : 9
    Par défaut
    Merci, pour votre réponses:

    Le but de cette partition est que la table table1 est plus grande (+40 millions enregistrements), et la recherche faite sur le champ champ2 sous la clause like avec la jointure d'une autre table.

    Exemple table1(champ1, champ2, champ3, champ4) (champ1 est PK)
    table2(ch1, ch2, ch3) (ch1 est PK, ch2 est FK de table1)

    La requête: select champ1, champ2, ch3
    from table1, table2
    where champ1 = ch2
    and champ2 like (%abcd%)

    alors le but est de forcer la requête d'utiliser la partition ou les valeurs de champ2 sont non null (from table1 (partition p1), table2), pour avoir la meilleur temps de réponse

Discussions similaires

  1. Docs, Tutoriels et astuces Tomcat et JBoss (US)
    Par Ricky81 dans le forum Tomcat et TomEE
    Réponses: 4
    Dernier message: 13/03/2009, 21h00
  2. [Astuces] Ou se trouve la barre de tâche ?
    Par donkey dans le forum C++Builder
    Réponses: 4
    Dernier message: 11/09/2003, 13h28
  3. Partitionner avec fdisk
    Par saibe dans le forum Administration système
    Réponses: 4
    Dernier message: 13/08/2003, 10h01
  4. Astuces XML/XSLT
    Par haypo dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 25/06/2003, 08h42
  5. Réponses: 2
    Dernier message: 06/03/2003, 16h37

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