Oracle 저장 프로시저에서 매개변수를 사용하여 호출하는 방법

PHPz
풀어 주다: 2023-04-25 09:29:30
원래의
1940명이 탐색했습니다.

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_namehire_datesalary(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_nameemp_hire_dateemp_salary,然后通过调用存储过程 get_employee_details 并传入参数 101,同时将输出参数赋值给上述声明的变量。最后,使用 DBMS_OUTPUT 包中的 PUT_LINE 函数输出查询结果。

需要注意的是,DECLAREBEGIN 语句是必须的,因为它们表示了一个代码块的起始和结束。在代码块中,可以声明变量、调用存储过程、执行各种 SQL 语句等。

参数的类型

在定义存储过程的参数时,可以使用以下类型:

  • IN:表示输入参数,这些参数用于向存储过程中传递值。
  • OUT:表示输出参数,这些参数用于从存储过程中返回值。
  • IN OUT:表示既是输入参数又是输出参数。这些参数既能够向存储过程中传递值,又能从存储过程中返回值。

除了上述类型外,还可以使用 NOCOPYrrreee

위 코드는 employee_id(IN 유형 입력 매개변수), employee_name 등 4개의 매개변수가 있는 <code>get_employee_details라는 저장 프로시저를 생성합니다. , hire_datesalary(OUT 유형의 출력 매개변수). 저장 프로시저의 기능은 employee_id 매개변수를 기반으로 직원의 세부 정보를 쿼리하고 쿼리 결과를 출력 매개변수에 저장하는 것입니다.

저장 프로시저 호출

저장 프로시저가 성공적으로 생성된 후 EXECUTE 문을 사용하여 호출할 수 있습니다. 다음은 저장 프로시저를 호출하는 코드입니다.
    rrreee
  • 위 코드에서 먼저 세 개의 변수 emp_name, emp_hire_dateemp_salary를 선언합니다. , 저장 프로시저 get_employee_details를 호출하고 101 매개변수를 전달하면 출력 매개변수가 위에 선언된 변수에 할당됩니다. 마지막으로 DBMS_OUTPUT 패키지의 PUT_LINE 함수를 사용하여 쿼리 결과를 출력합니다.
  • DECLAREBEGIN 문은 코드 블록의 시작과 끝을 나타내기 때문에 필요하다는 점에 유의하세요. 코드 블록에서는 변수 선언, 저장 프로시저 호출, 다양한 SQL 문 실행 등을 수행할 수 있습니다.
  • 매개변수 유형
저장 프로시저의 매개변수를 정의할 때 다음 유형을 사용할 수 있습니다.

IN: 저장 프로시저에 값을 전달하는 데 사용되는 입력 매개변수를 나타냅니다. .

🎜OUT: 저장 프로시저에서 값을 반환하는 데 사용되는 출력 매개변수를 나타냅니다. 🎜🎜IN OUT: 입력 매개변수이자 출력 매개변수임을 나타냅니다. 이러한 매개변수는 저장 프로시저에 값을 전달하거나 저장 프로시저에서 값을 반환할 수 있습니다. 🎜🎜🎜위 유형 외에도 NOCOPY 키워드를 사용하여 매개변수를 정의할 수 있습니다. 이를 통해 매개변수 전송 중 메모리 복사를 방지하여 실행 효율성을 높일 수 있습니다. 🎜🎜애플리케이션 시나리오🎜🎜실제 개발에서는 저장 프로시저의 매개변수 호출이 매우 일반적이며 여러 시나리오에 적용될 수 있습니다. 다음은 몇 가지 일반적인 응용 프로그램 시나리오입니다. 🎜🎜🎜매개 변수가 있는 쿼리: 저장 프로시저에서 입력 매개 변수를 정의하면 저장 프로시저가 다양한 입력 매개 변수를 기반으로 다양한 쿼리 문을 실행할 수 있으므로 매개 변수가 있는 쿼리를 실현할 수 있습니다. 🎜🎜일괄 작업: 스토어드 프로세스에서 입력 매개변수와 출력 매개변수를 정의할 수 있으므로 스토어드 프로세스는 입력 매개변수를 기반으로 일괄 작업을 수행하고 동시에 처리 결과를 출력 매개변수에 저장하여 비용을 줄일 수 있습니다. 후속 작업 수. 🎜🎜트랜잭션 처리: 저장 프로시저에서 입력 매개변수를 사용하여 트랜잭션 제출 또는 롤백을 제어할 수 있으므로 보다 유연한 트랜잭션 처리 방법을 얻을 수 있습니다. 🎜🎜🎜요약🎜🎜이 글에서는 Oracle 저장 프로시저에서 매개변수 호출을 사용하는 방법을 소개합니다. 일반적으로 저장 프로시저에 대한 매개 변수화된 호출은 코드 재사용성과 유연성을 크게 향상시키고 애플리케이션에 보다 유연한 기능을 제공할 수 있습니다. 따라서 실제 개발에서는 시스템 성능과 유지 관리성을 향상시키기 위해 저장 프로시저의 매개 변수화된 호출을 최대한 활용해야 합니다. 🎜

위 내용은 Oracle 저장 프로시저에서 매개변수를 사용하여 호출하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿