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

Accès aux données Discussion :

Oracle, insert + sequence, returning id.


Sujet :

Accès aux données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2007
    Messages
    187
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mai 2007
    Messages : 187
    Par défaut Oracle, insert + sequence, returning id.
    Bonjour,

    y à t'il un moyen de retourner l'id d'un row nouvellement inséré en C# avec oracle.

    un truc du genre :
    requette = Insert into maTable (ID, value) set (maSequence, 'valeur')
    Returning ID

    id = myOracleCommand.ExecuteNonQuery();

    de sorte que la valeur retourné par mon insert soit l'ID du row inséré.

    je fait ca en Java, mais je ne trouve pas l'astuce en .Net

    Merci.

    P.

  2. #2
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Il existe pour cela une option spécifique aux objets Oracle de System.data.OracleClient

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
           OracleString rowIdRet;
           myOracleCommand.ExecuteOracleNonQuery( out rowIdRet);
    Il est vrai qu'elle présente le gros inconvénient de "spécialiser" ton code pour Oracle.

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2007
    Messages
    187
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mai 2007
    Messages : 187
    Par défaut
    salut bluedeep,

    ca m'a l'air bien mais comment ExecuteOracleNonQuery sait-il quelle valeur me retourner.
    Quelle doit etre la synatxe de la requette.

    Merci en tous cas, ca pousse dans le bon sens.

    P.

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2007
    Messages
    187
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mai 2007
    Messages : 187
    Par défaut
    Je comprends, ExecuteOracleNonQuery( out rowIdRet) retourne le RowID.
    Ce n'est pas exactement ce que je cherchais...

    En fait j'aimerias avoir la clé primaire (crée par la sequence) afin de pouvoir faire référence à cette clé ailleurs...

    P.

  5. #5
    Rédacteur
    Avatar de The_badger_man
    Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2005
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 745
    Par défaut
    Pourquoi ne pas passer par une procédure stockée qui effectue ta requête et renvoie l'ID ?
    Les règles du forum
    Le trio magique : FAQ + Cours + fonction rechercher
    Mes articles
    Pas de questions par messages privés svp

    Software is never finished, only abandoned.

  6. #6
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2007
    Messages
    187
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mai 2007
    Messages : 187
    Par défaut
    Citation Envoyé par The_badger_man Voir le message
    Pourquoi ne pas passer par une procédure stockée qui effectue ta requête et renvoie l'ID ?
    une procedure stoqué est peut etre un peut lourd (à mon gout)

    en java j'execute une proceduree "en ligne", par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
            BEGIN
                insert into TRAITEMENTS (FTR_ID, FTR_FET_ID, FTR_FFU_ID, FTR_FPG_ID, FTR_MESSAGE, FTR_DATE_DEBUT) 
                values (S_TRAITEMENTS.nextval, 0, ?, ?, ?, sysdate)
                returning FTR_ID INTO ?;
            END;
    comment puis-je faire ca en .Net

    P.

  7. #7
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par pdelorme Voir le message
    Je comprends, ExecuteOracleNonQuery( out rowIdRet) retourne le RowID.
    Ce n'est pas exactement ce que je cherchais...
    En fait j'aimerias avoir la clé primaire (crée par la sequence) afin de pouvoir faire référence à cette clé ailleurs...
    Désolé d'avoir répondu à coté de la plaque, mais comme je n'aime pas le concept de séquence, je ne l'utilise presque jamais et ne me suis jamais penché plus en avant sur la question.
    Quand je dois l'utiliser (travail avec un modèle de données pré-existant au projet) c'est via une proc. stoc. qui me le retournera.

Discussions similaires

  1. [OCILIB] [OCI] Oracle INSERT avec clause RETURNING ROWID
    Par agileone dans le forum Interfaces de programmation
    Réponses: 0
    Dernier message: 01/05/2014, 14h58
  2. [Oracle] Insertion d'une sequence
    Par sebastien00 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 20/10/2008, 12h38
  3. Oracle - insertion de données > 8000 chars.
    Par Rakken dans le forum SQL
    Réponses: 9
    Dernier message: 24/10/2006, 16h39
  4. [PL/SQL] EXECUTE IMMEDIATE et INSERT et RETURNING
    Par swirtel dans le forum Oracle
    Réponses: 2
    Dernier message: 18/04/2006, 09h25
  5. [Oracle] Insert avec récupération valeur de la cle
    Par Silvia12 dans le forum Oracle
    Réponses: 2
    Dernier message: 11/03/2006, 03h28

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