Oracle 저장 프로시저에서 매개변수를 사용하여 호출하는 방법
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
문을 사용하여 호출할 수 있습니다. 다음은 저장 프로시저를 호출하는 코드입니다. - rrreee
- 위 코드에서 먼저 세 개의 변수
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사에서는 행 별 데이터 처리를위한 PL/SQL 커서를 설명합니다. Cursor 선언, 개방, 가져 오기 및 폐쇄, 암시 적, 명시 적 및 참조 커서를 비교합니다. 효율적인 대형 데이터 세트 처리 및 루프 사용 기술

이 기사에서는 Oracle 데이터베이스 세그먼트 유형 (데이터, 인덱스, 롤백, 임시), 성능 영향 및 관리를 검토합니다. 최적의 효율성을위한 워크로드 및 데이터 특성을 기반으로 적절한 세그먼트 유형을 선택하는 것을 강조합니다.

이 기사는 Oracle 데이터베이스 성능 테스트 도구를 살펴 봅니다. 예산, 복잡성 및 모니터링, 진단, 워크로드 시뮬레이션 및보고와 같은 기능을 기반으로 올바른 도구 선택에 대해 논의합니다. 이 기사는 또한 효과적인 BO에 대해 자세히 설명합니다

이 기사는 전체 서버 설치없이 Oracle 데이터베이스와 상호 작용하는 데 필수적인 Oracle Database 클라이언트 도구를 살펴 봅니다. SQL*Plus, SQL Developer, Enterprise Manager 및 RMAN과 같은 일반적으로 사용되는 도구에 대해 자세히 설명합니다.

이 기사에서는 Oracle의 기본 테이블 스페이스 (시스템, sysaux, 사용자), 특성, 식별 방법 및 성능 영향을 검토합니다. 그것은 불이행에 의존하는 것에 반대하고, 별도의 테이블 스팩을 만드는 것의 중요성을 강조합니다.

이 기사는 SQL 명령을 사용하여 Oracle에서 사용자 및 역할을 만드는 방법을 설명하고 최소 특권의 원칙 및 정기 감사에 따라 역할 사용을 포함하여 사용자 권한을 관리하는 모범 사례에 대해 설명합니다.

이 기사는 Oracle 데이터베이스를 다운로드하여 사용자를 안내합니다. 에디션 선택 (Express, Standard, Enterprise), 플랫폼 호환성 및 라이센스 계약 수락을 강조하는 프로세스를 자세히 설명합니다. 시스템 요구 사항 및 에디션 Suitabil

이 기사는 민감한 데이터를 보호하기위한 솔루션 인 Oracle Data Masking 및 Subsetting (DMS)에 대해 자세히 설명합니다. 민감한 데이터 식별, 마스킹 규칙 정의 (셔플 링, 대체, 무작위), 작업 설정, 모니터링 및 배포가 포함됩니다.
