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

SQL Oracle Discussion :

ORA-20000: ORU-10027: buffer overflow, limit of 1000000 bytes!


Sujet :

SQL Oracle

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 10
    Points : 6
    Points
    6
    Par défaut ORA-20000: ORU-10027: buffer overflow, limit of 1000000 bytes!
    Bonjour,

    A l'exécution d'un script SQL (via un lanceur shell script), je me retrouve face à l'erreur suivante:

    ORA-20000: ORU-10027: buffer overflow, limit of 1000000 bytes

    Ce script contient des procédures de traçage dans des fichiers mais quasiment aucun DBMS_OUTPUT.PUT_LINE si ce n'est à la fin, voici en détails:

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    ------------------------------------------------------------------
     
    WHENEVER SQLERROR EXIT FAILURE ROLLBACK;
     
    SET ECHO OFF
    SET SERVEROUTPUT ON SIZE 1000000
    SET VERIFY OFF
    SET FEED OFF
     
    DECLARE
     
       [...]
     
    PROCEDURE TRACE(...) IS
    BEGIN
     
       [...]
     
    END TRACE;
     
    -- MAIN --
     
    BEGIN
     
    FOR CURSOR_1 IN ( SELECT ... )
     
    LOOP
     
      FOR CURSOR_2 IN ( SELECT ... )
     
      LOOP
     
         [...] (pas de DBMS_OUTPUT.PUT_LINE, uniquement du traçage via TRACE)
               (le curseur CURSOR_2 renvoie plus de 50000 lignes contenant chacune une dizaine de champs)
     
        *** ici intervient l'erreur: ORA-20000: ORU-10027: buffer overflow, limit of 1000000 bytes ***
     
      END LOOP;
     
    END LOOP;
     
    DBMS_OUTPUT.PUT_LINE('Je renvoie l'erreur ci erreur il ya, par exemple celle vue plus haut')
     
    ------------------------------------------------------------------
    Je n'arrive pas à comprendre d'où cela peut venir si ce n'est du curseur qui n'est pas déclaré avant mais incorporé directement.

    Quelqu'un a-t-il une idée?

    Merci d'avance,
    Cordialement,
    Ptiboua.

  2. #2
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    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 : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Il faut partir de l’évidence. Soit la procédure Trace soit une autre appelée dans le script utilise dbms_output.putline

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    SET SERVEROUTPUT ON SIZE 1000000

    ORA-20000: ORU-10027: buffer overflow, limit of 1000000 bytes
    t'as plus qu'à lire la doc maintenant et faire des recherches sur UTL_FILE par exemple pour orienter la sortie vers un fichier plutôt que l'écran

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 10
    Points : 6
    Points
    6
    Par défaut SET SERVEROUTPUT ON SIZE unlimited; ???
    Bonjour à tous,

    Voici une solution que l'on m'a proposé pour éviter de faire péter le buffer Oracle, cela présente t'il un risque au niveau de la base?

    Merci d'avance,
    Ptiboua.

  5. #5
    Membre du Club
    Inscrit en
    Janvier 2008
    Messages
    116
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 116
    Points : 66
    Points
    66
    Par défaut
    Bonjour,

    Tu peux également regarder mon post :
    curseur et dbms_output.put_line
    ça peut t'aider.

  6. #6
    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
    Points : 4 926
    Points
    4 926
    Par défaut
    je ne sais pas si c'est à cause de mes nouvelles lunettes mais je ne vois pas la version

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    set serverout on size unlimited
    (unlimited = 10gR2)

Discussions similaires

  1. ORA-20000 : SYS.DBMS_OUTPUT : line length overflow,
    Par bilalove dans le forum Oracle
    Réponses: 5
    Dernier message: 12/05/2006, 23h30
  2. Buffer overflow ?
    Par Albator5151 dans le forum Général Java
    Réponses: 6
    Dernier message: 08/02/2006, 01h23
  3. [oracle 9i] ORU-10027: buffer overflow
    Par jejam dans le forum Oracle
    Réponses: 7
    Dernier message: 01/09/2005, 13h05
  4. Erreur ORU-10027 : buffer overflow
    Par valerie90 dans le forum Oracle
    Réponses: 3
    Dernier message: 14/02/2005, 08h40
  5. [Erreur] buffer overflow
    Par cmoulin dans le forum Administration
    Réponses: 8
    Dernier message: 04/08/2004, 14h36

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