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 :

delete très long


Sujet :

Oracle

  1. #1
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    95
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2005
    Messages : 95
    Points : 88
    Points
    88
    Par défaut delete très long
    Re-bonjour,
    (en 8.1.6 sous solaris)
    j'ai une table à purger mais pas en totalité.

    par exemple pour tester un delete de 10lignes.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    delete from customer where emp_id='ELECTRA' and rownum<11;
    y'a un index sur emp_id.

    les delete prennent beaucoup de temps, 22sec pour deleter 10lignes.
    cette table comporte 4 FK mais pas paramètrées en DELETE CASCADE, donc je ne pense pas que ca vienne de là.

    Elle comporte également 4 index. Est-ce que la suppression des index(sauf la PK) durant les delete améliorera bcq les temps, il y a 700000 lignes.

    Il y a 2 triggers, un en insert, l'autre en update, donc ce ne devrait pas être ca non plus ?

    D'ou peuvent provenir les pertes de temps ?
    locks sur la table, contention sur les redologs.

    avez-vous déjà rencontrés ce problème ?

    Merci

    Sébastien
    DBA SQLServer, Oracle, Mysql, DB2, Postgresql

  2. #2
    Expert Oracle confirmé

    Homme Profil pro
    Consultant Big Data
    Inscrit en
    Mars 2003
    Messages
    448
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Consultant Big Data
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2003
    Messages : 448
    Points : 926
    Points
    926
    Par défaut
    Bonjour,

    Il ne faut surtout pas supprimer tes index posés sur les FK.

    En effet, lors du delete dans la table mère, Oracle recherche si il n'y a pas d'occurrences enfants dans ces 4 tables, au moyen des 4 index.

    Si tu supprimes les index, alors Oracle devra balayer les tables enfants pour voir si ces occurrences existent ou pas, ce qui est beaucoup plus long.

    Peux-tu tracer le plan d'exécution de ton delete STP ?
    En fait, je suppose que, bien qu'il y ait un index sur EMP_ID, il ne doit pas être utilisé, car pas assez sélectif.

    Sur tes 700000 lignes, combien as-tu de valeurs différentes de EMP_ID ?

  3. #3
    Membre averti

    Inscrit en
    Septembre 2003
    Messages
    425
    Détails du profil
    Informations forums :
    Inscription : Septembre 2003
    Messages : 425
    Points : 398
    Points
    398
    Par défaut
    Si tu es vraiement sur des tes intégritées tu peux les désactiver.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    ALTER TABLE table_name
    disable CONSTRAINT constraint_name;
    Mais là je vois pas trop le but d'avoir des contraints

    Certe mais si c'est une purge, on peux faire ca en s'assurant de supprimer tous les fils ensuite et des réactiver les contraintes désactivées

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    y a-t-il un index sur emp_id ?

  5. #5
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    95
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2005
    Messages : 95
    Points : 88
    Points
    88
    Par défaut
    pour répondre à rouardg,
    tu m'as permis de découvrir qu'il n'y avait pas d'index sur toutes les FK.
    Ca peut donc provenir de là ?

    il me semblait qu'en ne spécifiant pas DELETE on CASCADE sur les contraintes, oracle n'allait pas accèder aux tables filles.

    Voici le plan d'exécution, il utilise bien l'index à priori, même s'il n'est pas super sélectif. 24 valeurs différentes sur 100.000 rows au total.
    est-ce qu'en forcant un fullscan ca sera plus rapide. ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Operation	Object Name	Rows	Bytes	Cost	Object Node	In/Out	PStart	PStop
     
    DELETE STATEMENT Optimizer Mode=CHOOSE		4 K	 	416  	 	      	             	 
      DELETE	CUSTOMER	  	 	 	 	      	             	 
        COUNT STOPKEY		  	 	 	 	      	             	 
          TABLE ACCESS BY INDEX ROWID	CUSTOMER	4 K	151 K	416  	 	      	             	 
            INDEX RANGE SCAN	IDX_CUSTOMER_EMP_ID	4 K	 	13

    merci
    DBA SQLServer, Oracle, Mysql, DB2, Postgresql

  6. #6
    Expert Oracle confirmé

    Homme Profil pro
    Consultant Big Data
    Inscrit en
    Mars 2003
    Messages
    448
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Consultant Big Data
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2003
    Messages : 448
    Points : 926
    Points
    926
    Par défaut
    Garde ton index. L'optimiseur Oracle est suffisament intelligent pour choisir entre un Range Scan sur cet index, et un Full Scan sur la table.

    Sinon, concernant tes FK, à partir du moment où tu fais un delete sur la table mère, que les FK soient en DELETE CASCADE, en DELETE NULL ou sans clause particulière, il faut mettre des index sur les FK.

    Là en fait, comme tu delete 10 occurrences dans la table mère, tu te payes 40 full scan de tables enfants au total.

    Mon conseil : poses 4 index sur tes 4 FK, regénère tes stats, et effectue le delete. Cela devrait aller beaucoup plus vite.

    Pour info complémentaire, pour ta création d'index, tu peux faire des index composite si tu en as besoin, mais il faut que les colonnes de ta FK soient les colonnes leader de l'index.

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    que donne ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    delete /*+ FIRST_ROWS */ from customer where emp_id='ELECTRA' and rownum<11;
    Les stats sont à jour ?

  8. #8
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Citation Envoyé par slefevre01
    pour répondre à rouardg,
    tu m'as permis de découvrir qu'il n'y avait pas d'index sur toutes les FK.
    Ca peut donc provenir de là ?

    il me semblait qu'en ne spécifiant pas DELETE on CASCADE sur les contraintes, oracle n'allait pas accèder aux tables filles.
    merci
    Oui, ça peut provenir de là, surtout si ta table fille est grosse.
    Oracle vérifie tout le temps l'intégrité des données, donc il accède constamment aux FK.

    J'ai le cas d'une table des paramètres qui sont utilisés dans toutes les tables de la base. Un delete ou update d'une ligne de la PK met 5 minutes.
    En cas de suppression de plusieurs codes (je sais qu'ils ne sont utilisés nul part), je désactive les contraintes (2s), je passe mon delete (2s) et je réactive les contraintes (10 minutes).
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

Discussions similaires

  1. [10gR1] Delete très long (+ de 20 heures)
    Par marc85 dans le forum Administration
    Réponses: 12
    Dernier message: 23/07/2013, 19h34
  2. Changement de PK => Delete très long
    Par beubeu40 dans le forum SQL
    Réponses: 11
    Dernier message: 10/02/2010, 17h37
  3. DELETE très long sur grosse table partitionée
    Par glutock dans le forum SQL
    Réponses: 3
    Dernier message: 28/04/2008, 10h47
  4. [Oracle9i] Delete très long
    Par MoitieDeCigare dans le forum Oracle
    Réponses: 15
    Dernier message: 27/11/2006, 10h35
  5. Très long texte dans Quick Report - Comment faire ?
    Par delphi+ dans le forum Composants VCL
    Réponses: 2
    Dernier message: 21/08/2005, 22h18

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