Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 21/01/2011, 11h08   #1
Invité de passage
 
Jacky DECLERCQ
Inscription : janvier 2011
Messages : 3
Détails du profil
Informations personnelles :
Nom : Jacky DECLERCQ

Informations forums :
Inscription : janvier 2011
Messages : 3
Points : 0
Points : 0
Par défaut PB sur UPDATE

Bonjour à tous.

Voici ce qui m'amène, je tente cette requête :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
UPDATE JDCQ_TBOD99TC_GTS S --131 574 lignes
SET       IDINTGTC = (
SELECT IDINTGTC
FROM ODS.TBOD99TC T -- 53 043 lignes
WHERE S.NOCTRCAD   = T.NOCTRCAD
  AND       S.COTYP         = T.COTYP
  AND       S.IDGARGEN   = T.IDGARGEN
  AND       S.COCAT         = T.COCAT
  AND       S.COTRA         = T.COTRA
  AND       S.TYSTRTAR    = T.TYSTRTAR
  AND       NVL(S.TYAPPCOT,'S')   = T.TYAPPCOT
  AND       S.INGROTARAJO         = T.INGROTARAJO
  AND       T.FLDERIMG    = 1
  AND       T.DTFINIMA      = to_date ('12-31-9999', 'mm-dd-yyyy'))
Le SELECT ne ramène rien, l'UPDATE ne se réalise pas.

Le problème est qu'Oracle est dans les choux, rien ne se passe.

Je ne comprends pas.
JackyD est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 11h37   #2
Expert Confirmé Sénior
 
Avatar de mnitu
 
Homme Marius Nitu
Ingénieur développement logiciels
Inscription : octobre 2007
Messages : 3 311
Détails du profil
Informations personnelles :
Nom : Homme Marius Nitu
Localisation : France, Marne (Champagne Ardenne)

Informations professionnelles :
Activité : Ingénieur développement logiciels
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2007
Messages : 3 311
Points : 5 808
Points : 5 808
Oracle bouffe 50 K lignes avant que vous avez eu le temps de taper le commit et Carriage Return. Donc je pense que vous est plutôt bloqué dans votre update par un autre processus.
mnitu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 11h37   #3
McM
Expert Confirmé Sénior
 
Inscription : juillet 2003
Messages : 3 437
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 3 437
Points : 4 173
Points : 4 173
  1. L'update se fait sur toutes les lignes de JDCQ_TBOD99TC_GTS, le sous select est-il optimisé ? Vérifier l'explain plan si un index est bien pris.
  2. Citation:
    Oracle est dans les choux et rien ne se passe ..
    Vérifier les locks
__________________
More Code : More Bugs. Less Code : Less Bugs
McM est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 11h54   #4
Invité de passage
 
Jacky DECLERCQ
Inscription : janvier 2011
Messages : 3
Détails du profil
Informations personnelles :
Nom : Jacky DECLERCQ

Informations forums :
Inscription : janvier 2011
Messages : 3
Points : 0
Points : 0
Merci à vous.

J'ai ajouté un index sur toutes les colonnes de la clause WHERE de la table imbriquée.
Je ne pensais pas au vu de la volumétrie avoir à positionner cet index.
JackyD est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 11h55   #5
Membre chevronné
 
Avatar de Z3phur
 
Homme loic
Administrateur de base de données
Inscription : décembre 2007
Messages : 673
Détails du profil
Informations personnelles :
Nom : Homme loic
Âge : 37
Localisation : France, Val de Marne (Île de France)

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

Informations forums :
Inscription : décembre 2007
Messages : 673
Points : 773
Points : 773
Citation:
Envoyé par JackyD Voir le message
Bonjour à tous.

Voici ce qui m'amène, je tente cette requête :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
update JDCQ_TBOD99TC_GTS S --> 131 574 lignes
set       IDINTGTC = (
select IDINTGTC
from ODS.TBOD99TC T --> 53 043 lignes
where S.NOCTRCAD   = T.NOCTRCAD
  and       S.COTYP         = T.COTYP
  and       S.IDGARGEN   = T.IDGARGEN
  and       S.COCAT         = T.COCAT
  and       S.COTRA         = T.COTRA
  and       S.TYSTRTAR    = T.TYSTRTAR
  and       NVL(S.TYAPPCOT,'S')   = T.TYAPPCOT
  and       S.INGROTARAJO         = T.INGROTARAJO
  and       T.FLDERIMG    = 1
  and       T.DTFINIMA      = to_date ('12-31-9999', 'mm-dd-yyyy'))
Le SELECT ne ramène rien, l'UPDATE ne se réalise pas.

Le problème est qu'ORACLE est dans les choux, rien ne se passe.

Je ne comprends pas
Ne serait-il pas mieux de faire votre update en deux étapes :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
select IDINTGTC
into v_idintgtc
from ODS.TBOD99TC T --> 53 043 lignes
where S.NOCTRCAD   = T.NOCTRCAD
  and       S.COTYP         = T.COTYP
  and       S.IDGARGEN   = T.IDGARGEN
  and       S.COCAT         = T.COCAT
  and       S.COTRA         = T.COTRA
  and       S.TYSTRTAR    = T.TYSTRTAR
  and       NVL(S.TYAPPCOT,'S')   = T.TYAPPCOT
  and       S.INGROTARAJO         = T.INGROTARAJO
  and       T.FLDERIMG    = 1
  and       T.DTFINIMA      = to_date ('12-31-9999', 'mm-dd-yyyy');
puis :

Code :
1
2
update JDCQ_TBOD99TC_GTS S --> 131 574 lignes
set       IDINTGTC = v_idintgtc;
Cela évitera aussi de locker la table DCQ_TBOD99TC_GTS trop longtemps
__________________
==========================================
La justice sans la force est impuissante, la force sans la justice est tyrannique...
Z3phur est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 12h40   #6
Invité de passage
 
Jacky DECLERCQ
Inscription : janvier 2011
Messages : 3
Détails du profil
Informations personnelles :
Nom : Jacky DECLERCQ

Informations forums :
Inscription : janvier 2011
Messages : 3
Points : 0
Points : 0
Je ne peux mettre en place cette solution, car je perds la synchro entre la table en UPDATE et la table imbriquée
JackyD est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 13h54   #7
McM
Expert Confirmé Sénior
 
Inscription : juillet 2003
Messages : 3 437
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 3 437
Points : 4 173
Points : 4 173
Citation:
Envoyé par JackyD Voir le message
Merci à vous.

J'ai ajouté un index sur toutes les colonnes de la clause WHERE de la table imbriquée.
Je ne pensais pas au vu de la volumétrie avoir à positionner cet index.
Et bien, c'est normal, tu fais un update sur 131000 lignes, et pour chaque ligne il va récupérer des infos. Donc 130.000 fois un full de 50.000 lignes, ça fait beaucoup

PS : Sujet résolu ou pas ?
__________________
More Code : More Bugs. Less Code : Less Bugs
McM est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/01/2011, 14h16   #8
Expert Confirmé Sénior
 
Avatar de mnitu
 
Homme Marius Nitu
Ingénieur développement logiciels
Inscription : octobre 2007
Messages : 3 311
Détails du profil
Informations personnelles :
Nom : Homme Marius Nitu
Localisation : France, Marne (Champagne Ardenne)

Informations professionnelles :
Activité : Ingénieur développement logiciels
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2007
Messages : 3 311
Points : 5 808
Points : 5 808
Citation:
Envoyé par McM Voir le message
...Donc 130.000 fois un full de 50.000 lignes, ça fait beaucoup
C'est ça.
mnitu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2011, 19h07   #9
Membre du Club
 
Inscription : novembre 2008
Messages : 46
Détails du profil
Informations personnelles :
Localisation : Royaume-Uni

Informations forums :
Inscription : novembre 2008
Messages : 46
Points : 51
Points : 51
Le code suivant aurait peut etre corrige le tir sans avoir recours aux index.

Code sql :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
 
UPDATE (
SELECT s.IDINTGTC,
       t.IDINTGTC new_IDINTGTC
FROM  
       JDCQ_TBOD99TC_GTS S, --131 574 lignes
       ODS.TBOD99TC T
WHERE S.NOCTRCAD   = T.NOCTRCAD
  AND       S.COTYP         = T.COTYP
  AND       S.IDGARGEN   = T.IDGARGEN
  AND       S.COCAT         = T.COCAT
  AND       S.COTRA         = T.COTRA
  AND       S.TYSTRTAR    = T.TYSTRTAR
  AND       NVL(S.TYAPPCOT,'S')   = T.TYAPPCOT
  AND       S.INGROTARAJO         = T.INGROTARAJO
  AND       T.FLDERIMG    = 1
  AND       T.DTFINIMA      = to_date ('12-31-9999', 'mm-dd-yyyy')
	)
SET IDINTGTC = new_IDINTGTC

Je n'ai pas tester la requete en question et je serai curieux de savoir ce que cela vous evoque.
Jorafali est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2011, 23h45   #10
McM
Expert Confirmé Sénior
 
Inscription : juillet 2003
Messages : 3 437
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 3 437
Points : 4 173
Points : 4 173
Euh.. si t'as pas d'index, comment Oracle va faire la jointure ?
__________________
More Code : More Bugs. Less Code : Less Bugs
McM est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h31.


 
 
 
 
Partenaires

Hébergement Web