|
Publicité ' | |||||||||||||||||||||||
|
|
#1 |
|
Invité de passage
![]() Inscription : août 2006 Messages : 13 ![]() |
Bonjour à tous.
Je vous explique mon problème : je souhaite créer une protection contre la suppression de certains enregistrements de la base de données (Mysql 5.0), notamment l'utilisateur root de notre tablez d'utilisateurs. Je pensais donc faire ca avec un trigger (BEFORE Delete on xxx.matable), mais je ne vois pas comment faire pour stopper le cours de la requete. En clair, je vérifierai donc dans ce trigger quel enregistrement est en train d'etre supprimé. Si c'est un enregistrement repertorié comme protégé, je veux annuler la suppression initiée. Quelqu'un pourrait 'il m'aider ? Merci d'avance ! |
|
|
00
|
|
|
#2 |
![]() ![]() ![]() Antoine DinimantConsultant en Business Intelligence Inscription : octobre 2006 Messages : 5 854 ![]() |
C'est un peu le problème des triggers sous MySQL, ils ne permettent pas explicitement d'annuler l'événement. Tu as donc deux solutions laides :
- déclencher un INSERT qui vient compenser ton DELETE... cela peut être délicate si tu as des AUTO_INCREMENT, des contraintes de clé étrangère, voire des DELETE en cascade... - provoquer sciemment une erreur, comme envoyer un SELECT dans ton trigger, tenter d'insérer un NULL dans une colonne NOT NULL, etc. |
|
|
00
|
|
|
#3 |
|
Invité de passage
![]() Inscription : août 2006 Messages : 13 ![]() |
Ca perd carrement de l'intéret pour le coup
Et il n'existe pas de simili-exception, qui permette de faire planter l'éxécution ? Ca serait quand même plus propre :/ |
|
|
00
|
Copyright © 2000-2012 - www.developpez.com