Précédent   Forum des professionnels en informatique > Bases de données > PostgreSQL
PostgreSQL Forum PostgreSQL. Avant de poster -> F.A.Q PostGreSQL Tutoriels PostGreSQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 26/04/2006, 09h27   #1
Futur Membre du Club
 
Inscription : mai 2005
Messages : 35
Détails du profil
Informations forums :
Inscription : mai 2005
Messages : 35
Points : 18
Points : 18
Par défaut Interblocage -> suppression impossible

Bonjour,

voilà mon problème : j'ai deux tables t1 et t2.
Il y a un trigger before delete sur t1 qui supprime la ligne correspondante dans t2.
Sur t2, il y a un trigger before delete qui met à jour la ligne dans t1.
Du coup, un verrou est posé sur cette ligne (c'est une supposition, mais forte quand même) et la ligne initiale dans t1 n'est pas supprimée.

Je pourrais utiliser les contraintes de clés étrangères pour résoudre le problème (d'ailleurs ça fonctionne bien), mais je veux aussi pouvoir faire des contrôles avant de supprimer une ligne dans t1. Pas de problème, je crée un trigger before delete bloquant la suppression s'il y a un problème.

Seulement, je trouve que ça manque de sécurité. En effet, si par malheur le trigger est modifié par quelqu'un d'autre ou carrément supprimé, il se peut que le trigger ne fonctionne plus comme prévu et donc que des suppressions non désirées apparaissent.

Je voudrais donc pouvoir simuler les ON DELETE CASCADE avec des triggers, tout en évitant le problème de verrou sus-cité.

Est-ce que vous avez des pistes sur ce problème ?

Etienne
echataig est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/04/2006, 14h20   #2
Expert Confirmé Sénior
 
Avatar de GrandFather
 
Inscription : mai 2004
Messages : 4 490
Détails du profil
Informations personnelles :
Âge : 42

Informations forums :
Inscription : mai 2004
Messages : 4 490
Points : 5 049
Points : 5 049
Bonjour,

Citation:
Envoyé par echataig
Seulement, je trouve que ça manque de sécurité. En effet, si par malheur le trigger est modifié par quelqu'un d'autre ou carrément supprimé, il se peut que le trigger ne fonctionne plus comme prévu et donc que des suppressions non désirées apparaissent.
Les modifications ou suppressions de trigger n'étant (en principe) pas à la portée de l'utilisateur lambda, le risque me paraît faible... Et si l'utilisateur est suffisamment compétent et dispose des droits suffisants pour le faire, il n'y a pas grand-chose qui pourra l'arrêter.
__________________
FAQ XML
------------
« Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
Giacomo Leopardi
GrandFather est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 02h39.


 
 
 
 
Partenaires

Hébergement Web