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 Firebird Discussion :

Insertion + récupération id auto


Sujet :

SQL Firebird

  1. #1
    Membre actif Avatar de fremsoi
    Inscrit en
    Août 2003
    Messages
    201
    Détails du profil
    Informations forums :
    Inscription : Août 2003
    Messages : 201
    Points : 217
    Points
    217
    Par défaut Insertion + récupération id auto
    Salut,

    Je voulais savoir comment faire pour récupérer l'identifiant automatique ( generateur + trigger ) EN MEME TEMPS que l'insertion d'un tuple

    Merci

  2. #2
    Membre éclairé Avatar de plabrevo
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    547
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 547
    Points : 670
    Points
    670
    Par défaut
    Je ne saisis pas ce que signifie "generateur+trigger", mais, sous Oracle, la solution est probablement d'utiliser un FORALL RETURNING BULK COLLECT:

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
     
    DROP SEQUENCE dept_s
    /
    DROP TABLE dept
    /
    CREATE SEQUENCE dept_s
    START WITH 10000
    /
    CREATE TABLE dept
    (id      INTEGER
    ,n       INTEGER)
    /
     
     
    SET SERVEROUTPUT ON SIZE 1000000
     
    DECLARE
    TYPE t_array_integer          IS TABLE OF INTEGER INDEX BY BINARY_INTEGER;
     
    l_array_n                     t_array_integer;
    l_array_id                    t_array_integer;
     
    BEGIN
    l_array_n(1) := 1;
    l_array_n(2) := 2;
     
    FORALL i IN 1..l_array_n.COUNT 
      INSERT INTO dept
      (id
      ,n)
      VALUES
      (dept_s.nextval
      ,l_array_n(i))
      RETURNING id BULK COLLECT INTO l_array_id
      ;
     
    FOR i IN 1..l_array_id.COUNT LOOP
      dbms_output.put_line(l_array_id(i));
    END LOOP;
    END;
    /
    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
     
    SQL> @returning
     
    Sequence dropped.
     
     
    Table dropped.
     
     
    Sequence created.
     
     
    Table created.
     
    10000
    10001
     
    PL/SQL procedure successfully completed.

  3. #3
    Membre actif Avatar de fremsoi
    Inscrit en
    Août 2003
    Messages
    201
    Détails du profil
    Informations forums :
    Inscription : Août 2003
    Messages : 201
    Points : 217
    Points
    217
    Par défaut
    Generateur + trigger, c'est pour créer un dientifiant automatique.
    J'utilise le langage SQL mais sur une base de donnée Firebird Embedded

  4. #4
    Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 52
    Points : 58
    Points
    58
    Par défaut
    C'est possible uniquement dans FireBird 2 qui est actuellement en beta à cette adresse:
    http://firebird.sourceforge.net/inde...&id=fb2_beta01

    RETURNING Clause for Insert Statements

    The RETURNING clause syntax has been implemented for the INSERT statement, enabling the re-turn of a result set from the INSERT statement. The set contains the column values actually stored. Most common usage would be for retrieving the value of the primary key generated inside a BEFORE-trigger.

    Available in DSQL and PSQL.
    Syntax Pattern
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO ... VALUES (...) [RETURNING <column_list> [INTO <variable_list>]]
    Example(s)

    1.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT INTO T1 (F1, F2)
    VALUES (:F1, :F2)
    RETURNING F1, F2 INTO :V1, :V2;
    2.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT INTO T2 (F1, F2)
    VALUES (1, 2)
    RETURNING ID INTO :PK;
    Henri Gourvest
    http://www.progdigy.com

  5. #5
    Membre actif Avatar de fremsoi
    Inscrit en
    Août 2003
    Messages
    201
    Détails du profil
    Informations forums :
    Inscription : Août 2003
    Messages : 201
    Points : 217
    Points
    217
    Par défaut
    ok merci

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

Discussions similaires

  1. Requete d'insertion avec n° auto
    Par zapatta dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 24/07/2006, 10h37
  2. [INSERT] Récupération de la date courante
    Par OverCat dans le forum Requêtes
    Réponses: 4
    Dernier message: 01/02/2006, 21h07
  3. [JDBC] Insertion dans Access auto Increment
    Par sg-40 dans le forum JDBC
    Réponses: 4
    Dernier message: 09/11/2005, 22h14
  4. [Jdbc] insertion avec numero auto
    Par ice69 dans le forum JDBC
    Réponses: 2
    Dernier message: 31/10/2005, 19h19
  5. INSERT INTO numéro auto.
    Par Pfeffer dans le forum Langage SQL
    Réponses: 9
    Dernier message: 17/02/2005, 19h04

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