Précédent   Forum des professionnels en informatique > Bases de données > Oracle
Oracle Forum Oracle : le serveur, les outils, ... Voir F.A.Q Oracle Tutoriels 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 18/09/2007, 22h08   #1
Membre habitué
 
Inscription : février 2006
Messages : 139
Détails du profil
Informations personnelles :
Âge : 37
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2006
Messages : 139
Points : 126
Points : 126
Par défaut precision sur execution des requetes

Bonjour,

pouvez-vous m'expliquer ce que représente concrètement la phase de fetch dans une instruction Oracle(lecture des blocs...).
De cette réponse en decoulera sûrement: pourquoi pour un même ordre sql exécuté plusieurs fois, seule le fetch est executée(et pas execute)?

Merci par avance
kervoaz est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/09/2007, 22h26   #2
Membre éprouvé
 
Avatar de argoet
 
Inscription : mai 2002
Messages : 535
Détails du profil
Informations forums :
Inscription : mai 2002
Messages : 535
Points : 461
Points : 461
Bonsoir,

Vous aurez une réponse à votre question en réalisant une recherche sur les Curseurs ORACLE
Allez regarder aussi les excellents tuto de SheikYerbouti Qui traite de ce sujet

Voir F.A.Q Oracle Tutoriels Oracle
__________________
Signé : Capitaine Jean-Luc Picard
argoet est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/09/2007, 09h53   #3
Membre habitué
 
Inscription : février 2006
Messages : 139
Détails du profil
Informations personnelles :
Âge : 37
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2006
Messages : 139
Points : 126
Points : 126
Bonjour,

Avant de poster, j'avais essayer effectivement de trouver la reponse. J'avais vu cet article cependant je ne comprends toujours pas(faut dire je suis pas un cheval de course).
Citation:
* PARSE
Cette étape convertit l’instruction SQL en plan d’exécution.
Elle vérifie également que l’utilisateur bénéficie bel et bien des autorisations appropriées et que les tables , colonnes et autres objets de référence existent. Il a également une vérification syntaxique
* EXECUTE
Cette étape correspond à l’exécution effective de l’instruction par le serveur Oracle.
- Insert , update et Delete cette étape modifie les données ( et effectue les tris nécessaire ).
- Select : cette étape identifie les lignes concernées
* FETCH
Cette étape extrait les lignes par une requête et effectue le tri nécessaire.
Cette partie ne concerne donc que les instructions SELECT.
Pourquoi alors le nombre d'execute et de fetch peuvent être différents pour une requête (dans une trace par exemple)?
Merci
kervoaz est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/09/2007, 10h56   #4
Membre expérimenté

 
Inscription : décembre 2003
Messages : 480
Détails du profil
Informations forums :
Inscription : décembre 2003
Messages : 480
Points : 539
Points : 539
parce que toutes les rows ne sont pas forcément ramenées en une fois

ce qui permet parexemple d'appliquer différent traitement selon les valeurs rencontrées en parcourant le curseur
__________________

*** OPN Exadata Specialist ***
*** OCE Performance Tuning 11g ***
*** OCE Rac 10g ***
*** OCP DBA 9i-10g-11g ***
Marc Musette est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/09/2007, 18h09   #5
Membre habitué
 
Inscription : février 2006
Messages : 139
Détails du profil
Informations personnelles :
Âge : 37
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2006
Messages : 139
Points : 126
Points : 126
Tout d'abord merci pour vos réponses.
Je suis un peu lourd mais c'est toujours pas bien clair.

Pouvez vous préciser comment toutes les rows ne peuvent pas etre ramenées en 1 seul fetch?

Je crois qu'il va me falloir un dessin

Merci par avance
kervoaz est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/09/2007, 22h17   #6
Invité régulier
 
Inscription : septembre 2007
Messages : 7
Détails du profil
Informations forums :
Inscription : septembre 2007
Messages : 7
Points : 7
Points : 7
le fecth est une opération séquentielle ou le client demande un certain nombres de lignes à lui retourner.
fétcher cela consiste donc à récupérer, mais on ne désire pas récupérer un million de ligne en une fois par exemple de manière à ne pas avoir un tampon mémoire énorme nécessaire.
C'est pourquoi on fixe une taille de tampon ou arraysize ou fetchsize .
Tu as donc nbr fetch * arraysize = nbr de ligne retournée.

ce paramètre arraysize est important car il détermine également le nombre de bloc lus par oracle.

ex : imaginons que ta taille de bloc oracle soit de 8k et que les enregistrements que tu veux ramener pèse 100 octects.
si tu veux raméner tout le contenu de ce bloc soit 80 lignes et que ton arraysize soit de 1 tu feras donc 80 fetchs.

Mais tu devras lire également 80 fois ce bloc oracle.

J'espère que cette explication t'aide.
ycolin est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/09/2007, 14h44   #7
Membre habitué
 
Inscription : février 2006
Messages : 139
Détails du profil
Informations personnelles :
Âge : 37
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2006
Messages : 139
Points : 126
Points : 126
Par défaut Merci ycolin

Impec
c'est très clair maintenant.
Merci
kervoaz 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 14h54.


 
 
 
 
Partenaires

Hébergement Web