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 :

Une conversion dans un Trigger


Sujet :

SQL Firebird

  1. #1
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 043
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 043
    Points : 40 957
    Points
    40 957
    Billets dans le blog
    62
    Par défaut Une conversion dans un Trigger
    Bonjour,

    je butte sur un léger problème pour gérer une exception lors d'un cast

    l'ojbectif obtenir un numéro unique
    si l'ASSORTIMENT (code couleur) est numérique alors le nombre (EANNUMBER) sera égal à l'ASSORTIMENT , sinon , on fait une recherche du premier numéro valide . J'ai essayé plusieurs alternatives a ce code , sans succès

    FB2.1

    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
     
    SET TERM ^ ;
    ALTER TRIGGER ASSORTS_BI ACTIVE
    BEFORE INSERT OR UPDATE POSITION 0
    AS
    DECLARE VARIABLE tmp SMALLINT;
    BEGIN
      IF ((NEW.EANNUMBER IS NULL) OR (NEW.EANNUMBER=0)) THEN
       BEGIN
          NEW.EANNUMBER=CAST(NEW.ASSORTIMENT AS SMALLINT);
          WHEN ANY DO 
          BEGIN
             tmp=1;
             WHILE (EXISTS (SELECT ASSORTIMENT FROM ASSORTS WHERE NOM=NEW.NOM AND ASSORTIMENT=:TMP))
              DO TMP=:TMP+1;
             NEW.EANNUMBER=:TMP;
          END
       END      
     END^
    SET TERM ; ^
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 043
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 043
    Points : 40 957
    Points
    40 957
    Billets dans le blog
    62
    Par défaut

    il faut croire que ventre affamé ne fait pas du bon code , je ne cherchais pas au bon endroit . La phrase coupable est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     WHILE (EXISTS (SELECT ASSORTIMENT FROM ASSORTS WHERE NOM=NEW.NOM AND ASSORTIMENT=:TMP))
    qui aurait du être
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    WHILE (EXISTS (SELECT ASSORTIMENT FROM ASSORTS WHERE NOM=NEW.NOM AND EANNUMBER=:TMP))
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

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

Discussions similaires

  1. [SQL] récupérer une variable dans un trigger
    Par zekiller3 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 03/05/2007, 14h48
  2. Exécution d'une commande dans un Trigger
    Par Perr1 dans le forum Oracle
    Réponses: 6
    Dernier message: 08/04/2006, 00h14
  3. Réponses: 9
    Dernier message: 25/01/2006, 15h35
  4. Annuler une insertion dans un Trigger
    Par dreamanoir dans le forum Oracle
    Réponses: 2
    Dernier message: 10/01/2005, 13h04
  5. Réponses: 4
    Dernier message: 18/10/2004, 16h18

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