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

Développement SQL Server Discussion :

trigger insert table [2008R2]


Sujet :

Développement SQL Server

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2012
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 36
    Points : 26
    Points
    26
    Par défaut trigger insert table
    * Bonjour, *

    je veux créer un Trigger interdisant l’ajout d’une composition pour un produit ayant une quantité en stock inférieure à 100.

    voilà j'ai fait ce code , mais apparemment ça fonctionne pas bien

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    create trigger tr__ on dbo.composition 
    instead of insert
    as 
    begin
    declare @qte int
     
    select @qte=QuantiteUtilisee from composition;
    print @qte;
                if(@qte<=100)
                begin 
                raiserror('qte inferieru à 100',16,1);
                end 
    end
    * Merci *

  2. #2
    Membre éprouvé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    623
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 623
    Points : 1 049
    Points
    1 049
    Par défaut
    tu ne filtres pas la table composition avec ton produit ?
    Blog Perso | Kankuru (logiciel gratuit pour SQL Server)

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2012
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 36
    Points : 26
    Points
    26
    Par défaut
    non il y'a juste la table composition qui contient l'id de produit et l'id de parfum voici toutes les tables :
    - Parfum (Codpar, NomPar, PrixVente, DateProduction, DateSortie, NumLabo, Classe)
    - Laboratoire (NumLabo, DesignationLabo)
    - Produit (CodPro, DesignationPro, UniteMesurePro, PrixUnitairePro, QteStock)
    - Composition (CodPar, CodPro, QuantiteUtilisee)

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    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
    CREATE TRIGGER E_IU_composition
    ON dbo.composition 
    FOR INSERT, UPDATE
    AS 
    DECLARE @LIMITE_STOCK FLOAT;
    SET @LIMITE_STOCK = 100;
    IF EXISTS(SELECT NULL
              FROM   dbo.Produit AS P
                     INNER JOIN inserted AS i
                           ON P.CodPro = i.CodPro
              WHERE  QteStock < @LIMITE_STOCK)
    BEGIN
       ROLLBACK;
       RAISERROR('Au moins un produit de cette composition possède un stock inférieur à %d',  16, 1, @LIMITE_STOCK);
    END;
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

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

Discussions similaires

  1. Trigger : Insert into table tout les jours à 8h
    Par Monta^^ dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 20/04/2012, 11h32
  2. Trigger insert dans une table
    Par dhiaeddine2012 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 13/03/2012, 12h55
  3. Trigger sur table en INSERT
    Par salsamania dans le forum Développement
    Réponses: 7
    Dernier message: 28/09/2010, 16h27
  4. Trigger Insert after sur une même table
    Par soumimasen dans le forum PL/SQL
    Réponses: 3
    Dernier message: 29/05/2008, 18h49
  5. trigger insert entre 2 serveurs
    Par Shabata dans le forum Développement
    Réponses: 5
    Dernier message: 27/05/2004, 12h00

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