Précédent   Forum des professionnels en informatique > Bases de données > Firebird > SQL
SQL Forum d'entraide sur le SQL pour Firebird
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 15/12/2004, 21h17   #1
Membre éprouvé
 
Avatar de JustMe
 
Inscription : juillet 2002
Messages : 432
Détails du profil
Informations forums :
Inscription : juillet 2002
Messages : 432
Points : 441
Points : 441
Par défaut désactiver un trigger

Est il possible de désativer un trigger pour une opération particulière ensuite l'activer?
__________________
<On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**
http://www.mobile-tactile.com/
JustMe est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/12/2004, 10h43   #2
Membre Expert
 
Avatar de Barbibulle
 
Frédéric
Inscription : octobre 2002
Messages : 1 722
Détails du profil
Informations personnelles :
Nom : Frédéric
Âge : 42

Informations forums :
Inscription : octobre 2002
Messages : 1 722
Points : 2 025
Points : 2 025
Il est possible en effet de désactiver un trigger.

Mais ce n'est pas recommandé sur Interbase 6 pour des opérations régulières. Ou du moins il y a une contrainte.

Pour désactiver :
Code :
ALTER TRIGGER NOM_DU_TRIGGER INACTIVE;
Donc je parlais d'une contrainte :
Sur chaque table il existe un numéro de version (de 0 à 255 maximum).
A chaque changement d'une table par un Alter le numéro de version de la table est augmenté. Hélas arrivé à 255 changements on ne peux plus modifier la table . Ce qui peux arriver en mode développement.
Cependant on peut remettre ces compteurs de versions à zero en faisant un backup suivi d'un restore de la base.

Ce qui est genant c'est qu'un alter trigger inactive/active fait changer ce numéro de version et donc vous êtes autorisé qu'a 255 changement d'état entre deux backup/restore.

Il me semble que ce probleme a été corrigé dans Firebird 1.5 (pour les triggers, car pour le reste c'est utile d'avoir ce versionning des changements sur les tables). En ce qui concerne Interbase 7.x je ne sais pas si c'est différents.

Voilà donc pour une opération de maintenance oui pour une opération régulière et de type automatique, alors là il faut faire attention.

Sinon je vais vous donner une solution simple qui va fonctionner sous Interbase et firebird :

Vous créez une vue qui est l'exacte reflet de votre table. Vous créez les triggers dont vous avez besoin sur la vue et non sur la table.
Quand vous avez besoin que les triggers soient activés vous utilisez la vue et quand vous avez besoin qu'il ne le soient pas pour utilisez la table.
Barbibulle est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/12/2004, 16h56   #3
Membre éprouvé
 
Avatar de JustMe
 
Inscription : juillet 2002
Messages : 432
Détails du profil
Informations forums :
Inscription : juillet 2002
Messages : 432
Points : 441
Points : 441
Je ne te remercierais pas assez, t'es une banque de données. Merci.
__________________
<On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**
http://www.mobile-tactile.com/
JustMe 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 17h50.


 
 
 
 
Partenaires

Hébergement Web