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 :

pb curseur global dans package


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut pb curseur global dans package
    Bonjour,


    Je viens de créer un package pour traiter des données,
    je traite une table ou j'ai du rajouter unn champ pour l'identification de l'utilisateur.

    donc j'avais ...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    CREATE OR REPLACE PACKAGE BODY portail.gestion
    AS
       /* Déclaration des variables*/
       /* l_ pour local
          p_ pour paramètre
          g_ pour global
       */
     
       CURSOR cursor_apprenti IS SELECT * FROM apprenti_upload FOR UPDATE;
    Dans la même package je lance tous les traitements
    avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
       PROCEDURE mainappli()
       IS
     
       BEGIN
     
          control_og ();
          update_in ();
       END;
    /************************************************************************************/
    END gestion;
    /
    Or je dois passer un identifiant de session pour reconnaitre
    donc l'ouverture du cuseur dépend de cet identifiant. ouie

    donc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    CREATE OR REPLACE PACKAGE BODY portail.gestion
    AS
       /* Déclaration des variables*/
       /* l_ pour local
          p_ pour paramètre
          g_ pour global
       */
     
       CURSOR cursor_apprenti IS SELECT * FROM apprenti_upload where ident= ???? FOR UPDATE;
    ident comment le passer ??????

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
       PROCEDURE mainappli(identifiant varchar2)
       IS
     
       BEGIN
          /*je ne vois pas comment ouvrir le curseur global avec la nouvelle   condition sans tout réécrire*/
          control_og ();
          update_in ();
       END;
    /************************************************************************************/
    END gestion;
    /
    une idée

    Merci ...

    olivier

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 20
    Par défaut
    Il faut passer l'identifiant en parametre de ton package.

  3. #3
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut ET comment qu'il dit
    Bonjour,

    Euh, t'aurais pas un tchi exemple ??

    JE vais chercher, .... google mon ami ;_) ?

    cordialement olivier

  4. #4
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CURSOR cursor_apprenti (p_id IN VARCHAR2) 
    
     IS 
    SELECT * 
    FROM apprenti_upload 
    WHERE ident= p_id 
    FOR UPDATE;
    Note de l'auteur : SELECT * , c'est vilain !

  5. #5
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut merci encore
    bonjour,

    j'avoue select * pas beau, pas je dois traiter tous les champs

    donc ....

    Par contre, sans vouloir t'offenser ( bicnic je suis ).
    tu passes le paramètre par

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    monpackage(moncurseur)
    cordialement olivier

  6. #6
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par nathieb Voir le message
    j'avoue select * pas beau, pas je dois traiter tous les champs
    C'est pas une bonne excuse !
    Un jour, une colonne supplémentaire apparait dans la table et le curseur craque !
    Et une journée de perdu pour trouver le problème !

Discussions similaires

  1. Variable Global dans un Package
    Par AbouZaid dans le forum PL/SQL
    Réponses: 13
    Dernier message: 24/05/2011, 18h52
  2. Réponses: 3
    Dernier message: 14/05/2009, 17h53
  3. Initialisation des variables globales dans un package
    Par fred_hte_savoie dans le forum SQL
    Réponses: 2
    Dernier message: 17/04/2007, 10h26
  4. Variables globales dans fichiers entête
    Par benj_f04 dans le forum C++
    Réponses: 5
    Dernier message: 13/08/2004, 09h06
  5. Variable "globale" (dans plusieurs templa
    Par mattmat dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 17/06/2003, 19h22

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