Oracle은 대기업 수준 시스템의 개발 및 유지 관리에 자주 사용되는 잘 알려진 관계형 데이터베이스 관리 시스템입니다. Oracle에서 저장 프로시저와 트리거는 두 가지 매우 중요한 데이터베이스 개체입니다. 이 문서에서는 해당 기능과 사용 방법을 소개합니다.
1. 저장 프로시저
1. 함수
저장 프로시저는 컴파일되어 데이터베이스에 저장되는 SQL 문 집합입니다. 함수처럼 호출하여 입력 매개변수를 받고 결과를 반환할 수 있습니다. 저장 프로시저는 데이터 쿼리, 데이터 수정, 데이터 백업 등과 같은 다양하고 복잡한 작업을 완료할 수 있습니다. 이는 데이터베이스 프로그래밍 작업을 크게 단순화합니다.
2. 생성
Oracle에서 저장 프로시저를 생성하려면 SQL Developer 또는 SQL*Plus와 같은 도구를 사용하여 생성 및 편집할 수 있는 PL/SQL 언어를 사용해야 합니다. 다음은 저장 프로시저를 생성하는 간단한 예입니다.
CREATE OR REPLACE PROCEDURE p_add (x IN NUMBER, y IN NUMBER, z OUT NUMBER) IS BEGIN z := x + y; END p_add;
위 예에서는 두 개의 입력 매개변수 x와 y와 하나의 출력 매개변수 z가 있는 p_add라는 저장 프로시저를 정의합니다. 저장 프로시저의 본문에서 입력 매개변수 x와 y를 추가하고 결과를 출력 매개변수 z에 할당합니다.
3. 호출
저장 프로시저를 생성한 후 이를 호출하여 그 안에 있는 SQL 문을 실행할 수 있습니다. PL/SQL에서 저장 프로시저를 호출하는 방법에는 두 가지가 있습니다.
EXECUTE p_add(1,2,:OUT);
위 예에서는 매개변수 1과 2를 전달하고 OUT 매개변수 출력을 사용하여 p_add라는 저장 프로시저를 호출했습니다. 결과.
DECLARE a NUMBER; BEGIN p_add(1,2,a); DBMS_OUTPUT.PUT_LINE('The result is: ' || a); END;
위 예에서는 PL/SQL 블록을 사용하여 저장 프로시저를 호출하고 결과를 출력했습니다.
2. 트리거
1. 기능
트리거는 테이블에 대해 INSERT, UPDATE, DELETE 작업을 수행할 때 자동으로 일부 작업을 수행할 수 있는 특수 개체입니다. 트리거는 데이터 검증, 데이터 복제, 데이터 백업 등의 작업에 사용할 수 있습니다.
2. Create
Oracle에서 트리거를 생성하려면 SQL Developer 또는 SQL*Plus와 같은 도구를 사용하여 생성하고 편집할 수도 있습니다. 다음은 트리거 생성의 간단한 예입니다.
CREATE OR REPLACE TRIGGER trg_ins_emp BEFORE INSERT ON emp FOR EACH ROW BEGIN :NEW.create_time := SYSDATE; END trg_ins_emp;
위 예에서는 trg_ins_emp라는 트리거를 정의하고 각각의 새 레코드가 emp 테이블에 삽입되기 전에 create_time 필드에 현재 시간을 할당합니다.
위 예시에서 BEFORE 키워드는 데이터가 삽입되기 전에 트리거된다는 의미이고, FOR EACH ROW는 INSERT 문이 실행될 때마다 트리거된다는 의미입니다.
3.
을 호출하여 트리거를 생성한 후에는 수동으로 호출할 필요 없이 해당 테이블에 대해 INSERT, UPDATE, DELETE 작업만 수행하면 됩니다. 다음은 INSERT 작업을 수행하는 간단한 예입니다.
INSERT INTO emp (name, salary) VALUES ('Jack', 5000);
위 예에서는 emp 테이블에 레코드를 삽입했습니다. trg_ins_emp라는 트리거를 생성했기 때문에 레코드를 삽입하면 create_time 필드에 자동으로 값이 할당됩니다. 현재 시간까지.
3. 요약
저장 프로시저와 트리거는 Oracle에서 매우 중요한 두 가지 개체입니다. 이는 데이터베이스 프로그래밍 작업을 크게 단순화합니다. 저장 프로시저는 복잡한 SQL 작업을 캡슐화하여 코드의 유지 관리성과 재사용성을 크게 향상시킬 수 있습니다. 트리거는 반복 작업을 피하기 위해 테이블 작업 중에 일부 작업을 자동으로 수행할 수 있습니다. 이 기사가 독자들이 Oracle 데이터베이스의 저장 프로시저와 트리거를 더 깊이 이해하는 데 도움이 되기를 바랍니다.
위 내용은 Oracle의 저장 프로시저 및 트리거에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!