>데이터 베이스 >Oracle >Oracle 저장 프로시저의 매개변수 유형은 무엇입니까?

Oracle 저장 프로시저의 매개변수 유형은 무엇입니까?

青灯夜游
青灯夜游원래의
2022-01-25 15:03:036195검색

Oracle 저장 프로시저의 매개변수 유형은 다음과 같습니다. 1. 호출자가 프로세스에 값을 전달하는 것을 의미하는 입력 유형 2. 프로세스가 호출자에게 값을 전달하는 것을 의미하는 출력 유형(여러 값을 반환할 수 있음) . 입력 및 출력 유형. 이는 호출자가 프로세스에 값을 전달하고 프로세스가 호출자에게 값을 전달함을 의미합니다.

Oracle 저장 프로시저의 매개변수 유형은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, Oracle 11g 버전, Dell G3 컴퓨터.

oracle 저장 프로시저 매개변수 유형

1. in: 입력 유형, 즉 애플리케이션이 데이터를 oracle 저장 프로시저에 전달하여 호출자가 이 매개변수에 값을 전달함을 나타냅니다. in 프로세스는 읽기 전용 매개변수이며 이 유형의 매개변수는 저장 프로시저에서 수정할 수 없습니다.

2. 출력 유형, 프로세스가 호출자에게 값을 전송함을 나타냅니다.

3. in out: 위의 두 가지 특성을 모두 갖고 있지만 읽고 쓸 수 있는 입력 및 출력 유형입니다. 이는 호출자가 프로세스에 값을 전달한다는 의미입니다. 방문객.

입력 매개변수 확인:

기본 매개변수가 입력 유형이므로 위 그림에서는 BAcount 매개변수에 값을 할당할 때 오류가 보고됩니다.

해결책:

CREATE OR REPLACE PACKAGE body BAWQ_PROC_JGZX IS
PROCEDURE PROC_CSJGZX
(
    pproc VARCHAR2,
    BAcount int :=3
)
IS
 i int :=BAcount;  --定义变量,通过变量替代参数
BEGIN
     i:=BAcount;
dbms_output.put_line(i);
  delete CSJGZX;
  while i>0 LOOP
       i := i-1 ;  
           insert into CSJGZX (CSJGZX_PROC,id,bh,mc,data) values(pproc,SYS_GUID(),SYS_GUID(),'济南',cast(DBMS_RANDOM.VALUE(1,200) as int));
       commit;
   end loop;

END PROC_CSJGZX;
END BAWQ_PROC_JGZX;

간단히 말하면 in은 저장 프로시저가 호출될 때 저장 프로시저에 전달되는 메시지입니다. out은 저장 프로시저가 호출자에게 보낸 메시지입니다. in out은 둘 사이의 의사 소통을 의미합니다.

추천 튜토리얼: "Oracle Tutorial"

위 내용은 Oracle 저장 프로시저의 매개변수 유형은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.