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 :

Optimisation d'un delete


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    34
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 34
    Par défaut Optimisation d'un delete
    Bonjour,

    je continue avec mes demandes d'optimisation.

    J'aimerais optimiser un script de purge. tous les jours, les engistrements de plus de 65 jours de mes tables de faits sont purgés. Or cette purge est extrémement longue, environ 1 million d'enregistrements supprimés par heure.

    Volumétrie de la table : 45 millions d'enregistremnts
    Index de la table :
    (ma notation pour les index table(col[,col]) )
    * int_navigation(id_usage, id_session, tps_id, num_ordre_session) (ma clé primaire)
    * int_navigation(id_interne_ei)
    * int_navigation(id_interne_struct_liaison)
    * int_navigation(tps_id,id_session)
    * int_navigation(id_session)

    Voici le bout de procédure pl/sql que j'utilise. C'est tout simplement une boucle qui supprimer 100 000 enregistrements à la fois afin d'éviter de faire exploser mon RBS.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
       Loop
          delete from INT_NAVIGATION where TPS_ID < to_char(sysdate -65,'YYYYMMDD') and rownum <100000;
          exit when SQL%NOTFOUND;
          commit;
       end loop;
    L'ajout d'un index sur la colone TPS_ID n'apporte aucun gain de performance.
    J'ai essayé de dropper les index de la table et de les recréer ensuite, mais la reconstruction des index dure environ une heure, en sachant que je supprime 2million d'enregistrements en une heure quand les index sont droppés.
    A noter également que je ne dispose pas d'assez d'espace disque sur mon serveur de prod pour passer par une table temporaire.

    J'aimerais donc savoir comment optimiser ceci ?

    Merci d'avance
    Nico

  2. #2
    Membre expérimenté
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2005
    Messages
    250
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 250
    Par défaut
    Je pense qu'une table parttionnée ainsi qu'une purge qui mentionne la partition dans laquelle se trouve tes lignes à supprimer serait assez indiquée...

    L'idée étant de faire une partition "by range" de façon à retrouver facilement les valeurs à supprimer. Les range/partitions correspondant à tes journées.
    Cela devrait te faire 66 partitions il me semble et chaque jour tu en droperais une et en recréerai une autre.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    34
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 34
    Par défaut
    Je n'ai pas les droits pour partitionner la table et on ne me les donnera pas.

    Aurait tu une autre idée?

    Merci quand même

  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
    Par défaut
    Si l'option de partitionning est activé (payée plus exactement ) il peut être intéressant de partitionner l'index, ce qui est moins contraigrant pour les DBA... j'imagine que c'est eux qui t'ont interdit le partitionnement de la table

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    34
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 34
    Par défaut
    D'après les informations dont je dispose, le paritionnement ne serait pas activé

    c'est vraiment domage car vous allez l'air d'en parler comme d'une solution miracle )

  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
    en effet, c'est justement fait pour les purges de données en particulier... sinon, la clause sur ROWNUM est-elle pertinente ? C'est bien le nombre de lignes à supprimer ?

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

Discussions similaires

  1. Optimisation DELETE
    Par poups dans le forum Oracle
    Réponses: 25
    Dernier message: 29/11/2010, 11h24
  2. Optimisation Update ou Delete + Insert
    Par Invité dans le forum Requêtes
    Réponses: 8
    Dernier message: 31/12/2009, 14h59
  3. Optimisation d'un delete
    Par Christophe Charron dans le forum Requêtes
    Réponses: 5
    Dernier message: 21/12/2008, 23h04
  4. [Optimisation] SELECT avant un DELETE (base 10g)
    Par macben dans le forum Oracle
    Réponses: 2
    Dernier message: 23/05/2006, 17h42
  5. Optimisation de DELETE
    Par RitonLaBevue dans le forum Requêtes
    Réponses: 5
    Dernier message: 02/11/2005, 15h31

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