Déclenche les curseurs
Dans une base de données, un déclencheur est une procédure (segment de code) qui est exécutée automatiquement lorsque certains événements spécifiques se produisent dans un tableau / vue. Parmi ses autres utilisations, les déclencheurs sont principalement utilisés pour maintenir l'intégrité dans une base de données. Un curseur est une structure de contrôle utilisée dans les bases de données pour passer par les enregistrements de base de données. Il est très similaire à l'itérateur fourni par de nombreux langages de programmation.
Que sont les déclencheurs?
Un déclencheur est une procédure (segment de code) qui est exécutée automatiquement lorsque certains événements spécifiques se produisent dans un tableau / vue d'une base de données. Parmi ses autres utilisations, les déclencheurs sont principalement utilisés pour maintenir l'intégrité dans une base de données. Les déclencheurs sont également utilisés pour faire respecter les règles métier, audit des modifications de la base de données et des données de réplication. Les déclencheurs les plus courants sont les déclencheurs du langage de manipulation des données (DML) qui sont déclenchés lorsque les données sont manipulées. Certains systèmes de bases de données prennent en charge les déclencheurs sans données, qui sont déclenchés lorsque des événements de langage de définition de données (DDL) se produisent. Certains exemples sont des déclencheurs qui sont tirés lorsque des tables sont créées, pendant les opérations de validation ou de recul, etc. Ces déclencheurs peuvent être particulièrement utilisés pour l'audit. Le système de base de données Oracle prend en charge les déclencheurs de niveau de schéma (i.e. déclencheurs tirés lorsque les schémas de base de données sont modifiés) comme après la création, avant modifier, après modifier, avant la chute, après la chute, etc. Les quatre principaux types de déclencheurs pris en charge par Oracle sont les déclencheurs au niveau des lignes, les déclencheurs au niveau des colonnes, chaque type de ligne déclenche et pour chaque type de déclaration déclenche.
Que sont les curseurs?
Un curseur est une structure de contrôle utilisée dans les bases de données pour passer par les enregistrements de base de données. Il est très similaire à l'itérateur fourni par de nombreux langages de programmation. En plus de traverser les enregistrements dans une base de données, les curseurs facilitent également la récupération des données, l'ajout et la suppression des enregistrements. En définissant la bonne façon, les curseurs peuvent également être utilisés pour traverser à l'envers. Lorsqu'une requête SQL renvoie un ensemble de lignes, celles-ci sont en fait traitées à l'aide de curseurs. Un curseur doit être déclaré et attribué un nom, avant qu'il ne puisse être utilisé. Ensuite, le curseur doit être ouvert en utilisant la commande ouverte. Cette opération placerait le curseur juste avant la première rangée de l'ensemble des enregistrements. Ensuite, le curseur doit effectuer l'opération de récupération pour obtenir une ligne de données dans l'application. Enfin, le curseur doit être fermé en utilisant l'opération de fermeture. Les curseurs fermés peuvent être ouverts à nouveau.
Quelle est la différence entre les déclencheurs et les curseurs?
Un déclencheur est une procédure (segment de code) qui est exécutée automatiquement lorsque certains événements spécifiques se produisent dans une table / vue d'une base de données, tandis qu'un curseur est une structure de contrôle utilisée dans les bases de données pour passer par l'enregistrement de la base de données. Un curseur peut être déclaré et utilisé dans un déclencheur. Dans une telle situation, la déclaration de déclaration serait à l'intérieur du déclencheur. Ensuite, la portée du curseur serait limitée à ce déclencheur. Dans un déclencheur, si un curseur est déclaré sur une table insérée ou supprimée, un tel curseur ne serait pas accessible à partir d'un déclencheur imbriqué. Une fois un déclencheur terminé, tous les curseurs créés dans le déclencheur seront désalloués.