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

Langage SQL Discussion :

Trigger pour une gestion de stock


Sujet :

Langage SQL

  1. #1
    Candidat au Club
    Inscrit en
    Novembre 2010
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 5
    Points : 3
    Points
    3
    Par défaut Trigger pour une gestion de stock
    Bonjour,
    Je suis débutante en langage SQL. Dans mon entreprise on souhaite gérer un stock de pièces. J'ai 4 tables ( Pièce, Possèder, Objet, Expedition). La table Possèder fait le lien entre Objet et Pièce. Ce que je veux moi, c'est que quand dans ma table Expedition j'ajoute un objet x, grâce à mon trigger , la table pièce est mis à jour. J'ai regarder sur différents sites mais je n'arrive pas à faire le lien entre les exemples donnés et ma table.
    Je vous remercie d'avance

  2. #2
    Membre actif
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mars 2002
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Mars 2002
    Messages : 244
    Points : 200
    Points
    200
    Par défaut
    Bonjour,

    Pourrais-tu être plus explicite par rapport aux champs de tes tables?

    Ce que je veux moi, c'est que quand dans ma table Expedition j'ajoute un objet x, grâce à mon trigger , la table pièce est mis à jour.
    Tu veux mettre à jour ta table PIECE ou ajouter ton objet X à la table PIECE?

    Prenons le cas ou tu dois ajouter l'objet X à ta table PIECE...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    delimiter $$
    CREATE TRIGGER insert_Objet
    AFTER insert ON Expedition FOR EACH ROW
    BEGIN
     
    	INSERT into PIECE (champ_1, ..., champ_n)/*Nom des champs de ta table Piece*/
            VALUES (new.champ_1,...,new.champ_n));/*Nom des champs de ta table expédition*/
     
    END$$
    delimiter ;
    champ_1 est le nom d'un champ que tu vas insérer automatiquement
    new.champ_1 est le nom du champ comportant la nouvelle valeur que tu as insérée.

    Par exemple:
    Si tu fais:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT into EXPEDITION (nom_objet_expedition) 
    VALUES ('objetX');
    Cela aura pour conséquence de provoquer la ligne suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    INSERT into PIECE (nom_objet_piece) 
    VALUES ('objetX'); /*Ici 'objetX' est la valeur de new.nom_objet_expedition*/

  3. #3
    Candidat au Club
    Inscrit en
    Novembre 2010
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Bonjour,
    Merci pour ta réponse. mais je ne veux pas ajouter un objet à la tables piece. Je veux que quand dans expedition j'ajoute un objet, dans la table piece (NomPiece, Nombre) le nombre diminue des pieces qui sont utilisées par l'objet.
    Si tu veux je peux t'envoyer mon MCD et mon modèle relationnel pour que tu comprenne mieux

  4. #4
    Membre actif
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mars 2002
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Mars 2002
    Messages : 244
    Points : 200
    Points
    200
    Par défaut
    Essaye quelque chose comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    delimiter $$
    CREATE TRIGGER insert_Objet
    AFTER INSERT ON Expedition FOR EACH ROW
    BEGIN
       SET PIECE.quantite = PIECE.quantite - new.quantite
       FROM PIECE
       WHERE PIECE.piece_ID = new.piece_ID;
    END$$
    delimiter ;
    Je ne peux malheureusement pas tester.
    Il faudra aussi gérer le cas ou tu n'as plus assez de pieces en stock!
    Ici, on part de l'exemple de ta table expédition.
    Tu devras aussi gérer l'approvisionnement en stock.
    Par exemple, une table livraison sur laquell etu mets un trigger qui fera
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    PIECE.quantite = PIECE.quantite + new.quantite

Discussions similaires

  1. Réponses: 5
    Dernier message: 19/02/2015, 19h23
  2. [Entité-Association] Problème pour définir le schéma pour une Gestion de Stock
    Par Netzo dans le forum Schéma
    Réponses: 8
    Dernier message: 06/01/2012, 15h41
  3. Quel langage pour une gestion des stocks-client-caisse ?
    Par plex dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 07/04/2007, 19h56
  4. Idées pour une gestion de droits d'accès a des Forms ?
    Par sfxElrick dans le forum Composants VCL
    Réponses: 17
    Dernier message: 26/01/2005, 17h00

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