Précédent   Forum des professionnels en informatique > Bases de données > Oracle > PL/SQL
PL/SQL Forum d'entraide sur le PL/SQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 15/02/2006, 00h15   #1
Invité de passage
 
Inscription : juillet 2005
Messages : 2
Détails du profil
Informations forums :
Inscription : juillet 2005
Messages : 2
Points : 0
Points : 0
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
Mithral est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/02/2006, 13h58   #2
Nouveau Membre du Club
 
Inscription : novembre 2005
Messages : 45
Détails du profil
Informations forums :
Inscription : novembre 2005
Messages : 45
Points : 39
Points : 39
Je dirais que non, la seule manière d'y accéder est d'utiliser la "dot notation' ;-)
goplay est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/02/2006, 17h09   #3
Invité de passage
 
Inscription : juillet 2005
Messages : 2
Détails du profil
Informations forums :
Inscription : juillet 2005
Messages : 2
Points : 0
Points : 0
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)
Mithral est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/02/2006, 18h04   #4
Membre actif
 
Inscription : décembre 2005
Messages : 138
Détails du profil
Informations personnelles :
Localisation : Canada

Informations forums :
Inscription : décembre 2005
Messages : 138
Points : 157
Points : 157
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!
bpprive est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 08h41.


 
 
 
 
Partenaires

Hébergement Web