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

PL/SQL Oracle Discussion :

Problème avec un simple SELECT


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    50
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 50
    Par défaut Problème avec un simple SELECT
    Bonjour à tous.

    J'ai un soucis avec une PL/SQL qui fait tourner un SELECT, voici le code de la PL :

    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
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
     
    PROCEDURE P_UPDATE_FLOW(P_MTH_REF Number,P_FILE_NAME CHAR, P_STATUS CHAR, P_STAT out Number) is
     
    --==============================================================================================
    -- Objectif : Cette procédure met à jour le statut d'un fichier
    -- Tables en Entrée  :	Aucune
    -- Tables en Sortie  :  Aucune
    -- Param Entrée      :
       -- P_MTH_REF : Mois de la mise en production de la forme 200302
       -- P_FILE_NAME : Nom du fichier
    -- Param Sortie      :	P_STAT
       -- Valeurs de retour possibles :
       	  		  -- 0 ==> fichier pas encore chargé pour le mois courant
    			  -- 1 ==> fichier déjà traité
    -- cree le 16/09/2008		par MPC
    --==============================================================================================
     
     
    ------------------------------------------------------------------------------
    -- Declaration de variables
    ------------------------------------------------------------------------------
    -- Nom de Procedure
    T_STATUS		    varchar2(1);
    -- Nom de Procedure
    T_NOM_PROC			varchar2(50);
    -- Message de fin de traitement
    T_MSG				varchar2(2000);
    --Type de processus
    T_TYP_PROCESS Varchar2(20);
     
    Procedure P_CALL_LOG_DET Is
    Begin
    -- ===================================
    --	Log erreur de traitement
    -- ===================================
      PCK_LGD_UTILS.P_LOG_DET
      (
        T_NOM_PROC			  ,
        T_TYP_PROCESS,
        SQLCODE,
    	T_MSG,
        To_Char(P_MTH_REF),
        0
      );
    End;
    ------------------------------------------------------------------------------
    -- Debut de Traitement
    ------------------------------------------------------------------------------
    BEGIN
     
    DBMS_OUTPUT.PUT_LINE('début');
    --Initialisation de variables de log
      T_NOM_PROC:='P_UPDATE_FLOW';
      T_TYP_PROCESS:=PCK_LGD_PARAMS.ADM;
      DBMS_OUTPUT.PUT_LINE('query is :');
      DBMS_OUTPUT.PUT_LINE(P_MTH_REF||' and '||P_FILE_NAME);
     
      SELECT STATUS INTO T_STATUS
      FROM LGD_GUI_LOAD
      WHERE
    	FILE_NAME = P_FILE_NAME ;
     
    		DBMS_OUTPUT.PUT_LINE('test du status');
    	if (T_STATUS = 'I') then
    	   	UPDATE LGD_GUI_LOAD
      		SET STATUS = P_STATUS, LOAD_DATE=SYSDATE
      		WHERE MTH_REF = P_MTH_REF AND FILE_NAME = P_FILE_NAME ;
    		DBMS_OUTPUT.PUT_LINE('MAJ date');
    	else
    		UPDATE LGD_GUI_LOAD
      		SET STATUS = P_STATUS
      		WHERE MTH_REF = P_MTH_REF AND FILE_NAME = P_FILE_NAME ;
    		DBMS_OUTPUT.PUT_LINE('pas de MAJ date');
    	end if;
     
    		DBMS_OUTPUT.PUT_LINE('fin');
     
    -------------------------------------------------------------------------------------------------------
    -- Insertion de la ligne
    -------------------------------------------------------------------------------------------------------
     
     
     
      COMMIT;
     
      P_STAT := 1 ;
    		DBMS_OUTPUT.PUT_LINE('fin');
     
    EXCEPTION
     
    	WHEN Others then
    	begin
    		rollback;
    		P_STAT:=0;
    		T_MSG:=T_MSG||' '||SqlErrm(SqlCode);
    		P_CALL_LOG_DET;
    	end;
    ------------------------------------------------------------------------------
    --	Fin de procedure
    ------------------------------------------------------------------------------
    end P_UPDATE_FLOW;
    Quand je la teste, il ne rentre pas dans le test IF (l'affichage ne fait pas).
    Si je gère l'exception NO_DATA_FOUND, il renvoie bien l'erreur NO_DATA_FOUND alors que si je teste le SELECT à la mano cela retourne un résultat.

    La table est bien renseigné.

    Merci d'avance, je désespère là...

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Salut,
    Citation Envoyé par houpli Voir le message
    alors que si je teste le SELECT à la mano cela retourne un résultat.
    Combien de lignes sont retournées ?
    Tu devras peut être gérer l'exception TOO_MANY_ROWS, modifier ta requête, ou passer par un curseur.
    PS : ton DBMS_OUTPUT.PUT_LINE('test du status'); est mal placé pour savoir si tu rentres dans le IF.

  3. #3
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    Comment appelles-tu ta procédure ?

    Remplace :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DBMS_OUTPUT.PUT_LINE(P_MTH_REF||' and '||P_FILE_NAME);
    par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DBMS_OUTPUT.PUT_LINE(P_MTH_REF||' and '||P_FILE_NAME || '#');
    et indique nous le résultat de cette ligne.

  4. #4
    McM
    McM est déconnecté
    Expert confirmé

    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
    Billets dans le blog
    4
    Par défaut
    Je sais pas comment est géré le CHAR dans les paramètres de procédure.
    Remplace P_FILE_NAME IN CHAR par P_FILE_NAME IN VARCHAR2

    Il nous manque le résultat des DBMS_OUTPUT, ce sera mieux pour savoir où il passe.

  5. #5
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    Citation Envoyé par McM Voir le message
    Je sais pas comment est géré le CHAR dans les paramètres de procédure.
    Ils se comportent comme des varchar2 :
    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
    SQL> create or replace procedure p1(c in char, v in varchar2) is
      2  begin
      3    dbms_output.put_line ('[' || c || ']');
      4    dbms_output.put_line ('[' || v || ']');
      5  end;
      6  /
    Procedure created.
     
    SQL> exec p1('c', 'v');
    [c]
    [v]
     
    SQL> declare
      2     var_c char(30);
      3  begin
      4    var_c := 'c';
      5    p1(var_c, var_c);
      6  end;
      7  /
    [c                             ]
    [c                             ]
     
    SQL> declare
      2    var_v varchar2(30);
      3  begin
      4    var_v := 'v';
      5    p1(var_v, var_v);
      6  end;
      7  /
    [v]
    [v]

Discussions similaires

  1. VB6 - problème avec listbox a selection multiple
    Par captainamerica75 dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 30/05/2007, 15h04
  2. probléme avec le " de ("SELECT login . . .
    Par mecmec dans le forum Langage
    Réponses: 5
    Dernier message: 21/05/2007, 11h35
  3. Sudo problème avec les simples quotes
    Par Tronche dans le forum Shell et commandes GNU
    Réponses: 5
    Dernier message: 23/03/2007, 12h02
  4. Problème avec XML::Simple
    Par ViRouF dans le forum Modules
    Réponses: 7
    Dernier message: 10/04/2006, 17h17
  5. [MySQL] Problème avec un champ selected
    Par Mimisator dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 03/01/2006, 17h01

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