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

Oracle Discussion :

Insertion dans un Nested table de ref


Sujet :

Oracle

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2009
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2009
    Messages : 13
    Par défaut Insertion dans un Nested table de ref
    Bonjour,

    J'ai un probleme niveau insertion dans un nested table voila l'example :


    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
    ***Le type Terme
    create type Terme_T as Object
    (
    	libelle varchar2(50),
    	TermesAssocies GroupeTermes
    )
    /
     
    ***La collection des termes
    create type GroupeTermes as table of ref Terme_T 
    /
     
    ***La table terme
    create table Terme of Terme_T
    (	
    	constraint pk_terme primary key(libelle)
    ) 
    nested table TermesAssocies store as TA_TAB;
     
     
    insert into Terme values('Sport de balle',null);
    ***insertion de Sport de balle effectuer
    insert into Terme values('Sport Collectif',GroupeTermes((select ref(i) from Terme i where libelle='Sport de balle'));
    ***insertion effectuer
    Par contre Je n'arrive pas a inserer directement dans le nested table!
    J'ai essayé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table(select TermesAssocies from terme where libelle='Sport de balle') values ((select ref(i) from terme i where i.libelle='Sport Collectif'));
    et j ai la message : referance to NULL table value !

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Celui-là il est assez complexe dans la compréhension.

    Le fait qu'une table imbriquée doit posséder une première référence qui pointe vers la table principale entraîne qu'on doit commencer par faire un update pour la première valeur, des insert pour les suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    UPDATE Terme
       set TermesAssocies = GroupeTermes((SELECT ref(i) FROM terme i WHERE i.libelle = 'Sport Collectif'))
     where libelle = 'Sport de balle';
    -- 1 row updated.
     
    INSERT INTO TABLE(SELECT TermesAssocies FROM terme WHERE libelle = 'Sport de balle')
    VALUES ((SELECT ref(i) FROM terme i WHERE i.libelle = 'Sport Collectif'));
    -- 1 row inserted.

Discussions similaires

  1. Réponses: 4
    Dernier message: 13/03/2009, 13h55
  2. Trigger d'insertion dans une nouvelle table
    Par Marty000 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 24/10/2006, 17h24
  3. Deux 'insert' dans la même table
    Par Arola78 dans le forum Access
    Réponses: 2
    Dernier message: 24/10/2006, 10h02
  4. Réponses: 9
    Dernier message: 20/10/2006, 14h32
  5. [ODBC] Récupération d'une donnée pour insertion dans une autre table
    Par rom950 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 10/03/2006, 17h13

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