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 :

manipulation du curseur avec oracle


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de hammag
    Profil pro
    Inscrit en
    Février 2006
    Messages
    511
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 511
    Par défaut manipulation du curseur avec oracle
    bonjour,

    voici mon problème :
    je cherche à remplir avec des données une table TAB2, cette dernière table contient un champ id que je doit le récuperer dans une autre table TAB1.

    j'ai cherché sur le web et j'ai trouvé que le curseur est la réponse à ma question. Donc, j'ai essayé avec cette requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    DECLARE id varchar(10); CURSOR curseur1 IS SELECT oprid FROM TAB1;
    BEGIN
        OPEN curseur1;
         LOOP
           FETCH curseur1 INTO id;
           insert into TAB2 ('xxx', id, 'yyy')
           EXIT WHEN curseur1%NOTFOUND;
        END LOOP;
    END;
    mais ca marche pas,

    svp, j'ai besoin d'aide

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Non la solution n’est pas un curseur mais un simple insert, quelque chose de ce type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Insert Into tab2 (col1, col2, col3) 
    Select 'xxx', id, 'yyy'
      From tab1

  3. #3
    Membre éclairé Avatar de hammag
    Profil pro
    Inscrit en
    Février 2006
    Messages
    511
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 511
    Par défaut
    non, en fait je veux copier juste un champ de la table TAB1 : id,
    les deux autre champs ne sont pas dans TAB1.

  4. #4
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Citation Envoyé par hammag Voir le message
    non, en fait je veux copier juste un champ de la table TAB1 : id,
    les deux autre champs ne sont pas dans TAB1.
    Salut !

    Dans ce cas, ils sont où ?
    La requête de Mnitu ne prenait que l'id dans tab1, et 'xxx' 'yyyy' pour les autres...

    Sinon, tu peux aussi t'embêter un peu moins sur le curseur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    BEGIN
        FOR curseur1 IN (SELECT id FROM Tab1)
         LOOP
           INSERT INTO TAB2 ('xxx', curseur1.id, 'yyy');
        END LOOP;
    END;
    [EDIT]
    Zut, je viens de m'apercevoir que je dis exactement la même chose que xdescamps
    (réveil difficile...)

  5. #5
    Membre chevronné Avatar de xdescamp
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 300
    Par défaut
    Citation Envoyé par hammag Voir le message
    mais ca marche pas,
    Mais encore ? Un message d'erreur par exemple ?

    Si les données ne viennent pas de TAB1, d'où viennent-elles ? L'instruction donnée par mnitu fait exactement ce que vous faites avec le curseur que vous nous avez montré, mais en plus performant.

  6. #6
    Membre chevronné

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    507
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 507
    Par défaut
    Bonjour.
    Juste pour coller à votre réponse, vous devez mettre le EXIT juste après le FETCH.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
        OPEN curseur1;
         LOOP
           FETCH curseur1 INTO id;
           EXIT WHEN curseur1%NOTFOUND;
           insert into TAB2 ('xxx', id, 'yyy');
        END LOOP;
    Et vous avez oublié le point-virgule à la fin de l'INSERT.

    Mais vous avez d'autres solutions comme indiqué par les précédents intervenants.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/10/2011, 12h30
  2. Réponses: 2
    Dernier message: 01/10/2007, 08h38
  3. Réponses: 14
    Dernier message: 01/09/2003, 15h54
  4. Conseils pour developper une application avec Oracle
    Par belugha dans le forum Langages de programmation
    Réponses: 5
    Dernier message: 02/06/2003, 16h03
  5. [Crystal Report 9] Changer de schéma avec Oracle
    Par sur_uix dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 14/11/2002, 12h19

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