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 :

Procedures stockée et séquence


Sujet :

PostgreSQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Directeur technique
    Inscrit en
    Mars 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2005
    Messages : 251
    Par défaut Procedures stockée et séquence
    Bonjour tout le monde !

    J'ai un probleme de sequence dans une procedure stockée

    Voici mon code
    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
    DECLARE identifiant ALIAS FOR $1;
    DECLARE r  record;
    BEGIN
    	SELECT INTO r * FROM inscription_temp WHERE id_ins = identifiant;
     
    	INSERT INTO francais (id_antiquaire, nom_antiquaire, nom_boutique, adresse_boutique, id_village, telephone, email, site, date_saisie, no_departement) 
    		VALUES (nextval('francais_id_antiquaire_seq'), r.nom || ' ' || r.prenom, r.nom_boutique, r.adresse, r.id_village, r.telephone, r.email, r.site, r.date_ins, r.departement);
     
    	IF r.spec1 IS NULL THEN
    	ELSE
    		INSERT INTO boutique_specialites VALUES (r.spec1, currval('francais_id_antiquaire_seq'), 1);
    	END IF;
     
    	IF r.spec2 IS NULL THEN
    	ELSE
    		INSERT INTO boutique_specialites VALUES (r.spec2, currval('francais_id_antiquaire_seq'), 2);
    	END IF;
     
    	IF r.spec3 IS NULL THEN
    	ELSE
    		INSERT INTO boutique_specialites VALUES (r.spec3, currval('francais_id_antiquaire_seq'), 3);
    	END IF;
     
    	DELETE FROM inscription_temp WHERE id_ins = identifiant;
     
    	return 0;
    END;
    En fait lors de l'appel, la contrainte de clé primaire sur la table francais (1ere insertion) se declenche. Donc il ne me prend pas la prochaine valeur de la séquence (7002) car mon plus gros id_antiquaire est 6800 !!

    Quelqu'un aurait-il une explication, SVP ?

    Merci beaucoup d'avance.

  2. #2
    Membre averti
    Inscrit en
    Janvier 2004
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 11
    Par défaut
    regarde ce tuttorial sur les sequences http://dgriessinger.developpez.com/p...equences/#LVII
    et à propos de ton code :
    soit tu utilises un trigger qui va te permettre qui va mettre ta cle primaire à la bonne valeur, soit tu le fais toi meme.

  3. #3
    Membre éclairé
    Homme Profil pro
    Directeur technique
    Inscrit en
    Mars 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2005
    Messages : 251
    Par défaut
    ok, je te remercie, je vais voir ca !

Discussions similaires

  1. Creation de séquence dynamiquement dans procedure stockée
    Par SOPSOU dans le forum Développement
    Réponses: 2
    Dernier message: 12/02/2014, 23h08
  2. Réponses: 1
    Dernier message: 04/06/2003, 11h48
  3. procedure stockée champ date
    Par tripper.dim dans le forum SQL
    Réponses: 5
    Dernier message: 25/04/2003, 09h47
  4. Appel a une procedure stockée en vba
    Par The_Nail dans le forum VBA Access
    Réponses: 36
    Dernier message: 01/04/2003, 16h44
  5. procedure stockée dans un dbbatch
    Par pram dans le forum XMLRAD
    Réponses: 4
    Dernier message: 07/02/2003, 16h35

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