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

 PostgreSQL Discussion :

recuperer la derniere cle primaire SERIAL ajouter


Sujet :

PostgreSQL

  1. #1
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    117
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Mars 2006
    Messages : 117
    Points : 109
    Points
    109
    Par défaut recuperer la derniere cle primaire SERIAL ajouter
    Bonjour,

    je m'arrache les cheveux depuis quelques temps. J'ecris actuellement une fonction en postgresql dans laquel je fais 2 insert. Je fais un insert dans une table dont la cle primaire est en Serial (auto increment.) Hors j'ai besoin de recuperer cette cle pour le 2eme insert... J'ai essayer de refaire un select ensuite du style :

    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
     
     
    DECLARE mavar INTEGER;
    BEGIN
    insert into matable(monchamp) values ("toto");
     
    select id INTO mavar from matable where monchamp= "toto";
     
    if (mavar IS NULL) then
     return false;
    end if;
     
    /* traitement avec mavar */
     
    END;
    Mais meme si le 1er insert a bien reussi (je verifie dans la base) la variable mavar est toujours NULL et ma function exit false.. Quand je test manuellement les commande 1 a 1 cela fonctionne...

    Je ne comprend pas ... voyez vous le probleme ? ou connaissez vous une autre technique pour faire cela ? (recuperer la derniere valeur d'un champ default)

  2. #2
    Membre averti
    Homme Profil pro
    Informaticien
    Inscrit en
    Juin 2004
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gers (Midi Pyrénées)

    Informations professionnelles :
    Activité : Informaticien
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juin 2004
    Messages : 182
    Points : 357
    Points
    357
    Par défaut
    Bonjour,

    vous pouvez utiliser la select nextval("nom de la sequence")
    ce qui vous retournera une id que vous pourrez utiliser dans le 1er et le 2ème INSERT.

    A+

  3. #3
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    Il y a une technique en une seule instruction avec RETURNING.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO ... VALUES(...) RETURNING id INTO variable;
    Sinon dans le bout de code montré, on ne voit pas de return true;
    Peut-être est-ce un oubli.
    Tu peux utiliser RAISE NOTICE 'message' pour t'assurer que le contrôle passe bien dans le IF.. IS NULL. A vue de nez si l'id est bien défini en SERIAL je dirais bien qu'il n'y passe pas. A moins que tu aies aussi une variable qui s'appelle id dans ta fonction auquel cas l'interpréteur plpgsql prendrait la valeur de cette variable et non pas celle de la colonne.

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/08/2007, 22h11
  2. Réponses: 6
    Dernier message: 03/05/2007, 23h48
  3. recuperer cle primaire en sql
    Par jpsegret dans le forum SQL
    Réponses: 2
    Dernier message: 02/05/2007, 15h13
  4. [MySQL] Récupérer la clé primaire d'une table et l'insérer dans une autre
    Par dorian67 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 31/10/2006, 15h23
  5. [Sql]Récupération clé primaire
    Par BillGates12345 dans le forum Oracle
    Réponses: 5
    Dernier message: 26/07/2006, 18h14

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