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

DB2 Discussion :

Annuler une insertion dans une table sur condition


Sujet :

DB2

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juillet 2004
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 29
    Points : 25
    Points
    25
    Par défaut Annuler une insertion dans une table sur condition
    Bonjour,
    je souhaite créer une "règle" qui empêche l'insertion une ligne dans une table si une condition "complexe" est validée.
    Lorsque je souhaite insérer une ligne dans la table A, je veux effectuer un "select count" sur la table B avec la clé de la table A et d'autres paramètres fixes qui rendent cette clé aussi unique dans la table B. Si le "select count" est non nul, je veux annuler l'insertion dans la table A.
    J'ai d'abord pensé à un trigger after update qui effectuerait un delete après coup mais je ne trouve pas ça "propre" car il peut y avoir d'autres triggers sur cette table.
    J'ai ensuite pensé à mettre en place une contrainte.....mais là, je sèche. Je n'arrive pas à lui "coller" mon "select count" dans le test initial. Je m'y prends certainement très mal mais je n'ai pas d'autre idée.
    Tout coup de pouce sera extrêmement bien accueilli!

    Merci par avance,
    Lionel

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Ingénieur d'Etude Mainframe/AS400
    Inscrit en
    Novembre 2012
    Messages
    1 767
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur d'Etude Mainframe/AS400
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2012
    Messages : 1 767
    Points : 10 778
    Points
    10 778
    Par défaut
    Bonjour,

    Pourquoi ne fais-tu pas d'abord le select dans ta table B pour ensuite déterminer si tu fais l'insert dans ta table A ?

  3. #3
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2010
    Messages
    946
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2010
    Messages : 946
    Points : 123
    Points
    123
    Par défaut
    bonjour,

    essaye avec cette methode
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    if (not exists(select champs1 from "table B" where (champs1=:cle)) then 
    insert into "table A" (champ1,champ2...) value(cle,var2...)

Discussions similaires

  1. Réponses: 2
    Dernier message: 27/10/2010, 21h38
  2. Réponses: 8
    Dernier message: 15/06/2010, 17h50
  3. Envoyer une formulaire dans une page dans une Frame
    Par zooffy dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 29/06/2007, 11h13
  4. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 14h48
  5. [MySQL] Insertion d'une image dans une div d'une news
    Par godsilken50 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 05/05/2007, 17h58

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