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

PL/SQL Oracle Discussion :

Trigger : remplir la valeur d'un champ via le résultat d'un calcul de deux autres champs


Sujet :

PL/SQL Oracle

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    SIGiste
    Inscrit en
    Juin 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : SIGiste

    Informations forums :
    Inscription : Juin 2018
    Messages : 3
    Points : 1
    Points
    1
    Par défaut Trigger : remplir la valeur d'un champ via le résultat d'un calcul de deux autres champs
    Bonjour à tous,

    Avant de vous exposer mon problème, je tiens à dire pour ma défense que je suis novice sur Oracle. Il se peut donc que des erreurs de syntaxe ou de vocabulaire se glissent dans mes propos et je m'en excuse d'avance.

    Cela étant dit, voici mon problème :

    J'ai actuellement une table contenant un champ du cout de la main d'œuvre "COUT_MO", un autre pour entrer les heures de travail "HEURES_MO" et un dernier réservé pour le cout global "COUT_GLOBAL".

    Mon but est de créer un trigger qui lorsque que l'un des deux premiers champs est rempli par un utilisateur, celui-ci entre le résultat du calcul "COUT_MO" * "HEURES_MO" dans le champ "COUT_GLOBAL".

    J'ai créé ce trigger qui se compile bien mais qui laisse mon champ ""COUT_GLOBAL" vide :

    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
     
    CREATE OR REPLACE TRIGGER "DEGAT_COUT_TTC" 
    BEFORE UPDATE of HEURES_MO, COUT_MO
    ON matable
    FOR EACH ROW
     
    Declare
     
    cout_ttc number;
     
    BEGIN
     
    select(:new.HEURES_MO * :new.COUT_MO) into cout_ttc from matable;
     
    :new.cout_global := cout_ttc;
     
    END;
    J'avoue que je tourne en rond depuis un moment, je suis donc preneur de toutes bonnes idées.

    D'avance merci.

  2. #2
    Membre émérite
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    1 993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 1 993
    Points : 2 499
    Points
    2 499
    Par défaut
    Il faut débugguer

    Que donne ceci (ce n'est pas garanti 0 bug car je n'ai pas testé...).

    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
    SET SERVEROUTPUT ON
     
    CREATE OR REPLACE TRIGGER "DEGAT_COUT_TTC" 
    BEFORE UPDATE of HEURES_MO, COUT_MO
    ON matable
    FOR EACH ROW
     
    Declare
     
    cout_ttc number;
     
    BEGIN
     
    select(:new.HEURES_MO * :new.COUT_MO) into cout_ttc from matable;
    DBMS_OUTPUT.PUT_LINE('new.HEURES_MO : ' || to_char(:new.HEURES_MO));
    DBMS_OUTPUT.PUT_LINE('new.COUT_MO : ' || to_char(:new.COUT_MO));
     
    :new.cout_global := cout_ttc;
     
    DBMS_OUTPUT.PUT_LINE('cout_ttc : ' || to_char(:cout_ttc));
    DBMS_OUTPUT.PUT_LINE('new.cout_global : ' || to_char(new.cout_global));
     
    END;
    DBA Oracle
    Rédacteur du blog : dbaoraclesql.canalblog.com

  3. #3
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Euh.. un select sur une table pour faire une multiplication ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select(:new.HEURES_MO * :new.COUT_MO) into cout_ttc from matable;
    En plus : PAS DE SELECT sur la table du TRIGGER en mode FOR EACH ROW

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE OR REPLACE TRIGGER "DEGAT_COUT_TTC" 
    BEFORE UPDATE of HEURES_MO, COUT_MO
    ON matable
    FOR EACH ROW
    Declare
    BEGIN
     :new.cout_global  := new.HEURES_MO * :new.COUT_MO;
    END;
    Que sur update ? Moi j'aurais mis l'insert aussi

    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
    CREATE TABLE wmc (HEURES_MO NUMBER, COUT_MO NUMBER, cout_global NUMBER)
     
    CREATE OR REPLACE TRIGGER "DEGAT_COUT_TTC" 
    BEFORE INSERT OR UPDATE OF HEURES_MO, COUT_MO ON wmc 
    FOR EACH ROW
    DECLARE
    BEGIN
     :NEW.cout_global  := :NEW.HEURES_MO * :NEW.COUT_MO;
    END;
     
    INSERT INTO wmc (heures_MO, cout_mo) VALUES(1, 10.5)
     
    SELECT * FROM wmc
     
    HEURES_MO	COUT_MO	COUT_GLOBAL
    1	10.5	10.5
     
    UPDATE wmc set heures_MO = 2
     
    SELECT * FROM wmc
     
    HEURES_MO	COUT_MO	COUT_GLOBAL
    2	10.5	21
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

  4. #4
    Nouveau Candidat au Club
    Homme Profil pro
    SIGiste
    Inscrit en
    Juin 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : SIGiste

    Informations forums :
    Inscription : Juin 2018
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Bonjour à vous deux et merci pour vos réponses.

    La solution de McM fonctionne parfaitement. Et je suis d'ailleurs navré de pas y avoir pensé tellement c'est évident.


    Citation Envoyé par McM Voir le message
    Euh.. un select sur une table pour faire une multiplication ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select(:new.HEURES_MO * :new.COUT_MO) into cout_ttc from matable;
    En plus : PAS DE SELECT sur la table du TRIGGER en mode FOR EACH ROW
    Désolé, comme je l'avais précisé en préambule de mon sujet, je n'ai pas de notions de langage SQL et je fais tout en m'aidant des forums comme le votre.

    Merci encore à vous deux et bonne journée.

  5. #5
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Citation Envoyé par Vincent_FR Voir le message
    Désolé, comme je l'avais précisé en préambule de mon sujet, je n'ai pas de notions de langage SQL et je fais tout en m'aidant des forums comme le votre.
    C'était plus destiné à Ikebukuro
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

  6. #6
    Nouveau Candidat au Club
    Homme Profil pro
    SIGiste
    Inscrit en
    Juin 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : SIGiste

    Informations forums :
    Inscription : Juin 2018
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Ah...Au temps pour moi.

  7. #7
    Membre émérite
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    1 993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 1 993
    Points : 2 499
    Points
    2 499
    Par défaut
    Je pouvais pas tester sinon j'aurai vu l'erreur
    DBA Oracle
    Rédacteur du blog : dbaoraclesql.canalblog.com

  8. #8
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Une solution disponible en 11g est d'utiliser une colonne virtuelle : on inscrit le calcul dans le DDL de la table, et on supprime le déclencheur :
    https://oracle-base.com/articles/11g...-columns-11gr1

Discussions similaires

  1. Réponses: 7
    Dernier message: 26/02/2013, 17h41
  2. champ à partir du calcul d'un autre champ
    Par maysa dans le forum Langage SQL
    Réponses: 8
    Dernier message: 28/08/2008, 16h08
  3. Réponses: 11
    Dernier message: 08/01/2008, 11h36
  4. [Table]champ calculé à partir des autres champs
    Par mjihanne dans le forum Access
    Réponses: 10
    Dernier message: 28/03/2007, 17h36
  5. Réponses: 5
    Dernier message: 02/08/2006, 13h29

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