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 :

Probleme d'affectation sur un objet ORACLE


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 14
    Par défaut Probleme d'affectation sur un objet ORACLE
    Apparemment sur un objet Oracle (Type) il est impossible de modifier
    directement les propriétés de cet objet dans une fonction membre (member function) alors que cela est possible dans une procédure, pourquoi ? :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    create or replace type body typ_test is
     
      member procedure proc(p in number) is begin
        self.maval := p*2; -- <<--ce ci est possible
      end proc;
     
      member function func(p in number) return number is begin
        self.maval := p*2; -- <<--ce ci est IMPOSSIBLE pourkoi et comment faire ?
        return self.maval /p;
      end func;
     
    end;
    Le message d'erreur est:
    "...
    expression 'SELF.MAVAL' ne peut être utilisée comme cible d'affectation
    ..."
    Pourquoi et comment contourner cela ?

    Merci d'avance

    EDIT par bouyao:

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    Il faut déclarer self en tant que paramètre in out (c'est du self service ):

    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
     
    > select * from v$version;
     
    BANNER
    ----------------------------------------------------------------
    Oracle9i Enterprise Edition Release 9.2.0.7.0 - 64bit Production
    PL/SQL Release 9.2.0.7.0 - Production
    CORE    9.2.0.7.0       Production
    TNS for HPUX: Version 9.2.0.7.0 - Production
    NLSRTL Version 9.2.0.7.0 - Production
     
    >
    > create or replace type typ_test as object
      2  ( maval number,
      3    member procedure proc(p in number),
      4    member function func(self in out typ_test, p in number) return number
      5  )
      6  /
     
    Type created.
     
    > show errors
    No errors.
    >
    > create or replace type body typ_test is
      2
      3      member procedure proc(p in number)
      4      is begin
      5      self.maval := p*2;
      6      end proc;
      7
      8      member function func(self in out typ_test, p in number) return number
      9      is begin
     10      self.maval := p*2;
     11      return self.maval;
     12      end func;
     13
     14  end;
     15  /
     
    Type body created.
     
    > show errors
    No errors

Discussions similaires

  1. probleme d'affichage sur objet TPaintBox
    Par Nephi dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/07/2008, 11h41
  2. Réponses: 2
    Dernier message: 28/06/2008, 10h08
  3. [Win32][2005perso]Probleme d'affectation sur variable Typée
    Par Qwazerty dans le forum Composants VCL
    Réponses: 4
    Dernier message: 12/08/2007, 23h55
  4. Réponses: 8
    Dernier message: 17/05/2006, 14h32
  5. [Oracle 9i] Déclencheur sur table objet
    Par Process Linux dans le forum Oracle
    Réponses: 5
    Dernier message: 28/01/2006, 09h53

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