Maison base de données Oracle Explication détaillée des procédures stockées et des déclencheurs d'Oracle

Explication détaillée des procédures stockées et des déclencheurs d'Oracle

Apr 21, 2023 am 10:10 AM

Oracle est un système de gestion de bases de données relationnelles bien connu, souvent utilisé dans le développement et la maintenance de grands systèmes au niveau de l'entreprise. Dans Oracle, les procédures stockées et les déclencheurs sont deux objets de base de données très importants. Cet article présentera leurs fonctions et comment les utiliser.

1. Procédure stockée

1. Fonction

Une procédure stockée est un ensemble d'instructions SQL compilées et enregistrées dans la base de données. Il peut être appelé comme une fonction, recevant des paramètres d'entrée et renvoyant un résultat. Les procédures stockées peuvent effectuer diverses opérations complexes, telles que l'interrogation de données, la modification de données, la sauvegarde de données, etc. Ils simplifient grandement le travail de programmation de bases de données.

2. Créer

Dans Oracle, la création d'une procédure stockée nécessite l'utilisation du langage PL/SQL, qui peut être créée et modifiée à l'aide d'outils tels que SQL Developer ou SQL*Plus. Voici un exemple simple de création d'une procédure stockée :

CREATE OR REPLACE PROCEDURE p_add (x IN NUMBER, y IN NUMBER, z OUT NUMBER) IS
BEGIN
  z := x + y;
END p_add;
Copier après la connexion

Dans l'exemple ci-dessus, nous définissons une procédure stockée nommée p_add, qui a deux paramètres d'entrée x et y et un paramètre de sortie z. Dans le corps de la procédure stockée, nous ajoutons les paramètres d'entrée x et y et attribuons le résultat au paramètre de sortie z.

3. Appel

Après avoir créé la procédure stockée, nous pouvons y exécuter l'instruction SQL en l'appelant. Il existe deux manières d'appeler des procédures stockées en PL/SQL :

  • Utilisez l'instruction EXECUTE :
EXECUTE p_add(1,2,:OUT);
Copier après la connexion

Dans l'exemple ci-dessus, nous avons appelé la procédure stockée nommée p_add, en passant les paramètres 1 et 2 et en utilisant la sortie du paramètre OUT résultat.

  • Utilisation du bloc PL/SQL :
DECLARE
  a NUMBER;
BEGIN
  p_add(1,2,a);
  DBMS_OUTPUT.PUT_LINE('The result is: ' || a);
END;
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé le bloc PL/SQL pour appeler la procédure stockée et afficher le résultat.

2. Déclencheurs

1. Fonction

Un déclencheur est un objet spécial associé à une table qui peut effectuer automatiquement certaines opérations lors de l'exécution d'opérations INSERT, UPDATE et DELETE sur la table. Les déclencheurs peuvent être utilisés pour des opérations telles que la vérification des données, la réplication des données et la sauvegarde des données.

2. Créer

Dans Oracle, la création d'un déclencheur nécessite l'utilisation du langage PL/SQL. Vous pouvez également utiliser des outils tels que SQL Developer ou SQL*Plus pour créer et modifier. Voici un exemple simple de création d'un déclencheur :

CREATE OR REPLACE TRIGGER trg_ins_emp
BEFORE INSERT ON emp
FOR EACH ROW
BEGIN
  :NEW.create_time := SYSDATE;
END trg_ins_emp;
Copier après la connexion

Dans l'exemple ci-dessus, nous définissons un déclencheur nommé trg_ins_emp et attribuons l'heure actuelle au champ create_time avant que chaque nouvel enregistrement ne soit inséré dans la table emp.

Dans l'exemple ci-dessus, le mot-clé BEFORE signifie que le déclencheur sera déclenché avant l'insertion des données, et FOR EACH ROW signifie qu'il sera déclenché à chaque fois que l'instruction INSERT est exécutée.

3. Après avoir appelé

pour créer un déclencheur, nous n'avons pas besoin de l'appeler manuellement. Il nous suffit d'effectuer les opérations INSERT, UPDATE et DELETE sur la table concernée pour déclencher le déclencheur. Voici un exemple simple d'exécution d'une opération INSERT :

INSERT INTO emp (name, salary) VALUES ('Jack', 5000);
Copier après la connexion

Dans l'exemple ci-dessus, nous insérons un enregistrement dans la table emp Puisque nous avons créé un déclencheur nommé trg_ins_emp, lors de l'insertion de l'enregistrement, le champ create_time attribuera automatiquement la valeur. à l'heure actuelle.

3. Résumé

Les procédures stockées et les déclencheurs sont deux objets très importants dans Oracle. Ils simplifient grandement le travail de programmation de base de données. Les procédures stockées peuvent encapsuler des opérations SQL complexes, améliorant considérablement la maintenabilité et la réutilisation du code. Les déclencheurs peuvent effectuer automatiquement certaines opérations pendant les opérations sur la table pour éviter un travail répétitif. J'espère que cet article pourra aider les lecteurs à mieux comprendre les procédures stockées et les déclencheurs de la base de données Oracle.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment créer des utilisateurs et des rôles dans Oracle? Comment créer des utilisateurs et des rôles dans Oracle? Mar 17, 2025 pm 06:41 PM

L'article explique comment créer des utilisateurs et des rôles dans Oracle à l'aide de commandes SQL, et discute des meilleures pratiques pour gérer les autorisations des utilisateurs, y compris l'utilisation des rôles, en suivant le principe des moindres privilèges et des audits réguliers.

Comment utiliser Oracle Data Masking and Unsetting pour protéger les données sensibles? Comment utiliser Oracle Data Masking and Unsetting pour protéger les données sensibles? Mar 13, 2025 pm 01:19 PM

Cet article détaille le masquage et le sous-ensemble des données Oracle (DMS), une solution pour protéger les données sensibles. Il couvre l'identification des données sensibles, la définition des règles de masquage (mélange, substitution, randomisation), mise en place de travaux, surveillance et déploiement

Comment utiliser les curseurs dans PL / SQL pour traiter plusieurs lignes de données? Comment utiliser les curseurs dans PL / SQL pour traiter plusieurs lignes de données? Mar 13, 2025 pm 01:16 PM

Cet article explique les curseurs PL / SQL pour le traitement des données Row-by Row. Il détaille la déclaration, l'ouverture, la récupération et la fermeture du curseur, comparant les curses implicites, explicites et ref. Techniques pour une manipulation efficace des ensembles de données importants et une utilisation pour des boucles

Comment effectuer des sauvegardes en ligne dans Oracle avec un minimum de temps d'arrêt? Comment effectuer des sauvegardes en ligne dans Oracle avec un minimum de temps d'arrêt? Mar 17, 2025 pm 06:39 PM

L'article traite des méthodes pour effectuer des sauvegardes en ligne dans Oracle avec un minimum de temps d'arrêt en utilisant RMAN, les meilleures pratiques pour réduire les temps d'arrêt, assurer la cohérence des données et surveiller les progrès de la sauvegarde.

Comment configurer le chiffrement dans Oracle à l'aide du chiffrement transparent des données (TDE)? Comment configurer le chiffrement dans Oracle à l'aide du chiffrement transparent des données (TDE)? Mar 17, 2025 pm 06:43 PM

L'article décrit les étapes pour configurer le chiffrement transparent des données (TDE) dans Oracle, détaillant la création du portefeuille, permettant le TDE et le chiffrement des données à différents niveaux. Il discute également des avantages de TDE comme la protection et la conformité des données, et comment Veri

Comment implémenter des politiques de sécurité dans Oracle Database à l'aide de la base de données privée virtuelle (VPD)? Comment implémenter des politiques de sécurité dans Oracle Database à l'aide de la base de données privée virtuelle (VPD)? Mar 13, 2025 pm 01:18 PM

Cet article détaille la mise en œuvre des politiques de sécurité des bases de données Oracle à l'aide de bases de données privées virtuelles (VPD). Il explique la création et la gestion des politiques VPD via des fonctions qui filtrent les données basées sur le contexte de l'utilisateur, mettant en évidence les meilleures pratiques comme le moins P

Comment utiliser le référentiel de charge de travail automatique (AWR) et le moniteur de diagnostic de base de données automatique (ADDM) dans Oracle? Comment utiliser le référentiel de charge de travail automatique (AWR) et le moniteur de diagnostic de base de données automatique (ADDM) dans Oracle? Mar 17, 2025 pm 06:44 PM

L'article explique comment utiliser AWR et ADDM d'Oracle pour l'optimisation des performances de la base de données. Il détaille la génération et l'analyse des rapports AWR, et l'utilisation d'ADDM pour identifier et résoudre les goulots d'étranglement des performances.

Comment utiliser la technologie Flashback pour se remettre de la corruption logique des données? Comment utiliser la technologie Flashback pour se remettre de la corruption logique des données? Mar 14, 2025 pm 05:43 PM

L'article discute de l'utilisation de la technologie Flashback d'Oracle pour se remettre de la corruption logique des données, des étapes de détail de la mise en œuvre et de la garantie de l'intégrité des données après la récupération.

See all articles