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 :

PLSQL : Record


Sujet :

PL/SQL Oracle

  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 2
    Par défaut PLSQL : Record
    Bonjour,

    Je voudrais savoir s'il est possible d'accéder aux champs d'un objet record autrement qu'en écrivant : <record>.<field1>

    En tapant le numéro de la colonne par exemple ?

    Un grand merci par avance

    Mithral

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2005
    Messages : 45
    Par défaut
    Je dirais que non, la seule manière d'y accéder est d'utiliser la "dot notation' ;-)

  3. #3
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 2
    Par défaut
    Merci pour ta réponse

    En fait j'étais bloqué sur un problème d'Update.

    Je voulais mettre à jour une série d'enregistrement d'une table B à partir des enregistrements équivalent d'une table A

    Au début j'avais fait une première requete sur A que je recupérais dans un curseur. Et pour chaque ligne du curseur je faisais un update dans B. Le problème c'est que je ne connaissais pas les valeurs en dur de chaque champs, de même que je ne connaissais pas non plus en dur le nom de la table.

    Du coup j'ai voulu faire une requete dynamique avec execute immediate.

    Dans un premier temps comme ci_dessus, en récupérant manuellement chaque valeur du record mais sans connaitre les noms des champs

    Comme tu m'as confirmé que ca n'est possible, j'ai pensé à set row mais pareil on peut pas binder un record à une requete dynamique.

    Heureusement, j'ai fini par trouver cette requette (j'étais pas très familier avec le update ^^) qui fait tout d'un coup, du coup plus de problème ^^ :

    update B set (Col1, Col2, Col3) = (select * from A where A.PrimaryKey = B.PrimaryKey)

  4. #4
    Membre expérimenté
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 138
    Par défaut
    Il pourrait aussi y avoir l'option du MERGE dans le cas où vous décidez que sour certaines conditions, soit vouos mettez à jour la table ou vous insérer une nouvelles ligne...

    Une espèce d'extension très permitive du UPDATE standard, dans une commande SQL et plutot plus performante qu'une boucle PL/SQL!

Discussions similaires

  1. [PLSQL] TYPE RECORD
    Par romuald9999 dans le forum Oracle
    Réponses: 13
    Dernier message: 19/08/2004, 15h18
  2. Stocker un record dans un fichier
    Par ushu dans le forum Langage
    Réponses: 7
    Dernier message: 13/12/2002, 15h51
  3. Structure de données de type "RECORD"
    Par chaours dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 30/09/2002, 17h10
  4. Record et TObject
    Par spirale dans le forum Langage
    Réponses: 2
    Dernier message: 13/09/2002, 12h06

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