Oracle 저장 프로시저는 데이터베이스에 저장되어 언제든지 실행하고 호출할 수 있는 사전 컴파일되고 재사용 가능한 SQL 문입니다. Oracle 저장 프로시저에서는 매개변수를 사용하여 보다 유연한 호출을 수행할 수 있습니다. 이 문서에서는 Oracle 저장 프로시저 호출에서 매개변수를 사용하는 방법을 설명합니다.
Oracle 데이터베이스에서 저장 프로시저를 생성하려면 CREATE PROCEDURE
문을 사용해야 합니다. 다음은 간단한 예입니다. CREATE PROCEDURE
语句。以下是一个简单的例子:
CREATE OR REPLACE PROCEDURE get_employee_details( employee_id IN NUMBER, employee_name OUT VARCHAR2, hire_date OUT DATE, salary OUT NUMBER ) AS BEGIN SELECT e.employee_name, e.hire_date, e.salary INTO employee_name, hire_date, salary FROM employees e WHERE e.employee_id = employee_id; END;
上面的代码创建了一个名为 get_employee_details
的存储过程,该存储过程具有四个参数:employee_id
(IN 类型的输入参数)、employee_name
、hire_date
和 salary
(OUT 类型的输出参数)。存储过程的作用是根据 employee_id
参数查询员工的详细信息,并将查询结果存储在输出参数中。
当存储过程创建成功后,就可以使用 EXECUTE
语句来调用它。以下是调用存储过程的代码:
DECLARE emp_name VARCHAR2(50); emp_hire_date DATE; emp_salary NUMBER; BEGIN get_employee_details(101, emp_name, emp_hire_date, emp_salary); DBMS_OUTPUT.PUT_LINE('Employee Name : ' || emp_name); DBMS_OUTPUT.PUT_LINE('Hire Date : ' || emp_hire_date); DBMS_OUTPUT.PUT_LINE('Salary : ' || emp_salary); END;
在上面的代码中,首先声明三个变量 emp_name
、emp_hire_date
和 emp_salary
,然后通过调用存储过程 get_employee_details
并传入参数 101
,同时将输出参数赋值给上述声明的变量。最后,使用 DBMS_OUTPUT
包中的 PUT_LINE
函数输出查询结果。
需要注意的是,DECLARE
和 BEGIN
语句是必须的,因为它们表示了一个代码块的起始和结束。在代码块中,可以声明变量、调用存储过程、执行各种 SQL 语句等。
在定义存储过程的参数时,可以使用以下类型:
IN
:表示输入参数,这些参数用于向存储过程中传递值。OUT
:表示输出参数,这些参数用于从存储过程中返回值。IN OUT
:表示既是输入参数又是输出参数。这些参数既能够向存储过程中传递值,又能从存储过程中返回值。除了上述类型外,还可以使用 NOCOPY
rrreee
employee_id
(IN 유형 입력 매개변수), employee_name 등 4개의 매개변수가 있는 <code>get_employee_details
라는 저장 프로시저를 생성합니다. , hire_date
및 salary
(OUT 유형의 출력 매개변수). 저장 프로시저의 기능은 employee_id
매개변수를 기반으로 직원의 세부 정보를 쿼리하고 쿼리 결과를 출력 매개변수에 저장하는 것입니다. 저장 프로시저 호출저장 프로시저가 성공적으로 생성된 후 EXECUTE
문을 사용하여 호출할 수 있습니다. 다음은 저장 프로시저를 호출하는 코드입니다. emp_name
, emp_hire_date
및 emp_salary
를 선언합니다. , 저장 프로시저 get_employee_details
를 호출하고 101
매개변수를 전달하면 출력 매개변수가 위에 선언된 변수에 할당됩니다. 마지막으로 DBMS_OUTPUT
패키지의 PUT_LINE
함수를 사용하여 쿼리 결과를 출력합니다. DECLARE
및 BEGIN
문은 코드 블록의 시작과 끝을 나타내기 때문에 필요하다는 점에 유의하세요. 코드 블록에서는 변수 선언, 저장 프로시저 호출, 다양한 SQL 문 실행 등을 수행할 수 있습니다. IN
: 저장 프로시저에 값을 전달하는 데 사용되는 입력 매개변수를 나타냅니다. .
OUT
: 저장 프로시저에서 값을 반환하는 데 사용되는 출력 매개변수를 나타냅니다. 🎜🎜IN OUT
: 입력 매개변수이자 출력 매개변수임을 나타냅니다. 이러한 매개변수는 저장 프로시저에 값을 전달하거나 저장 프로시저에서 값을 반환할 수 있습니다. 🎜🎜🎜위 유형 외에도 NOCOPY
키워드를 사용하여 매개변수를 정의할 수 있습니다. 이를 통해 매개변수 전송 중 메모리 복사를 방지하여 실행 효율성을 높일 수 있습니다. 🎜🎜애플리케이션 시나리오🎜🎜실제 개발에서는 저장 프로시저의 매개변수 호출이 매우 일반적이며 여러 시나리오에 적용될 수 있습니다. 다음은 몇 가지 일반적인 응용 프로그램 시나리오입니다. 🎜🎜🎜매개 변수가 있는 쿼리: 저장 프로시저에서 입력 매개 변수를 정의하면 저장 프로시저가 다양한 입력 매개 변수를 기반으로 다양한 쿼리 문을 실행할 수 있으므로 매개 변수가 있는 쿼리를 실현할 수 있습니다. 🎜🎜일괄 작업: 스토어드 프로세스에서 입력 매개변수와 출력 매개변수를 정의할 수 있으므로 스토어드 프로세스는 입력 매개변수를 기반으로 일괄 작업을 수행하고 동시에 처리 결과를 출력 매개변수에 저장하여 비용을 줄일 수 있습니다. 후속 작업 수. 🎜🎜트랜잭션 처리: 저장 프로시저에서 입력 매개변수를 사용하여 트랜잭션 제출 또는 롤백을 제어할 수 있으므로 보다 유연한 트랜잭션 처리 방법을 얻을 수 있습니다. 🎜🎜🎜요약🎜🎜이 글에서는 Oracle 저장 프로시저에서 매개변수 호출을 사용하는 방법을 소개합니다. 일반적으로 저장 프로시저에 대한 매개 변수화된 호출은 코드 재사용성과 유연성을 크게 향상시키고 애플리케이션에 보다 유연한 기능을 제공할 수 있습니다. 따라서 실제 개발에서는 시스템 성능과 유지 관리성을 향상시키기 위해 저장 프로시저의 매개 변수화된 호출을 최대한 활용해야 합니다. 🎜위 내용은 Oracle 저장 프로시저에서 매개변수를 사용하여 호출하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!