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

Forms Oracle Discussion :

Insertion dans une table après modification d'un champ


Sujet :

Forms Oracle

  1. #1
    Membre habitué
    Inscrit en
    Novembre 2007
    Messages
    390
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 390
    Points : 179
    Points
    179
    Par défaut Insertion dans une table après modification d'un champ
    Bonjour,

    J'ai deux tables article et audit_art. Je cherche comment enregistrer les modifications effectuées sur la quantité en stock pour un article depuis une forme en enregistrant le n° de série, la désignation, l'utilisateur qui a réalisé la modification, l'ancienne quantité et la nouvelle quantité dans la table audit_art.

    Merci pour vos propositions.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 102
    Points : 28 403
    Points
    28 403
    Par défaut
    Sans connaitre la structure de tes tables ni avoir quelques lignes d'exemples de données, il sera bien difficile de te répondre.

  3. #3
    Membre habitué
    Inscrit en
    Novembre 2007
    Messages
    390
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 390
    Points : 179
    Points
    179
    Par défaut
    Table Article:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    id_art number,
    reference varchar2(50),
    libelle varchar2(100),
    stock number,
    stock_min.
    Table Audit_art:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    id_audit number,
    ref_art varchar2(50),
    modificateur varchar2(100),
    date_modification date,
    stock_old number,
    stock_new number.
    Pour l'article suivant:

    1, '12050DD','Disque dur',20,5
    l'utilisateur 'X' a modifié la quantité en stock du 20 au 25 à partir de l'interface.

    donc dans la table Audit_art je doit avoir:

    1, '12050DD','X',11/03/2013 12:35, 20, 25.

    Merci.

  4. #4
    Membre actif Avatar de fahdijbeli
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Juin 2012
    Messages : 281
    Points : 240
    Points
    240
    Par défaut
    bonsoir,
    si j'avais compris votre problème utiliser les déclencheurs par exemple après une modification dans la table article ce déclencheur doit être lancé après cette modification pour modifier aussi la table audit_art

  5. #5
    Membre habitué
    Inscrit en
    Novembre 2007
    Messages
    390
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 390
    Points : 179
    Points
    179
    Par défaut
    Oui bien sur il faut utiliser un déclencheur après mise à jour, mais je cherche comment déclencher un déclencheur seulement en cas de modification de la quantité en stock ?????

  6. #6
    Expert éminent sénior
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Points : 11 862
    Points
    11 862
    Par défaut
    Dans la forme, vous pouvez savoir si la quantité à été modifiée en comparant avec la valeur de départ - Get_Item_Property( DATABASE_VALUE).

  7. #7
    Membre chevronné Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Points : 2 071
    Points
    2 071
    Par défaut
    Je pense qu'il est nettement mieux de faire ce genre de chose du coté Base !
    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 OR REPLACE TRIGGER ART_AU
       AFTER UPDATE OF STOCK
       ON ART
       REFERENCING NEW AS NEW OLD AS OLD
       FOR EACH ROW
    BEGIN
    IF nvl(:old.stock,0)<> nvl(:new.stock,0)
    THEN
       INSERT INTO audit_art (id_audit,
                              ref_art,
                              modificateur,
                              date_modification,
                              stock_old,
                              stock_new)
            VALUES (...,
                     :new.id_art,
                     USER,
                    SYSDATE,
                    :old.stock,
                    :new.stock);
    END IF;
    END;

  8. #8
    Membre habitué
    Inscrit en
    Novembre 2007
    Messages
    390
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 390
    Points : 179
    Points
    179
    Par défaut
    Parfait, c'est résolu.

    Merci Mr. Garuda et Mr. SheikYerbouti.

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

Discussions similaires

  1. Affichage popup après insertion dans une table
    Par PowerGel dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 19/03/2012, 12h08
  2. Réponses: 2
    Dernier message: 03/09/2008, 16h42
  3. [Sybase] Temps d'une insertion dans une table
    Par vsavoir dans le forum Décisions SGBD
    Réponses: 5
    Dernier message: 14/02/2005, 10h04
  4. Extraction d'un .txt et Insertion dans une table
    Par PoPmiSiR dans le forum Access
    Réponses: 8
    Dernier message: 28/10/2004, 19h13
  5. Détection insertion dans une Table
    Par abelman dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 06/07/2004, 14h24

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