1、無參數預存程序的調用
--建立無參預存程序
CREATE OR REPLACE FUNCTION stu_proc RETURN VARCHAR2 IS
--聲明語句段
v_name varchar2(20);
BEGIN
--執行語句段
SELECT o.sname INTO v_name FROM student o where o.id=1;
RETURN v_name;
END;
--調用無參預存程序
DECLARE
BEGIN
DBMS_OUTPUT.put_line('在PL/SQL中列印的結果:'||stu_proc);
END;
2、入參預存程序的調用
--建立入參預存程序
CREATE OR REPLACE FUNCTION stu_proc(v_id IN NUMBER) RETURN VARCHAR2 IS
--聲明語句段
v_name varchar2(20);
BEGIN
--執行語句段
SELECT o.sname INTO v_name FROM student o where o.id=v_id;
RETURN v_name;
END;
--調用入參預存程序
DECLARE
BEGIN
DBMS_OUTPUT.put_line('在PL/SQL中列印的結果:'||stu_proc(1));
END;
3、出參預存程序的調用
--建立出參預存程序
CREATE OR REPLACE FUNCTION stu_proc(v_name OUT VARCHAR2) RETURN VARCHAR2 IS
BEGIN
--執行語句段
SELECT o.sname INTO v_name FROM student o where o.id=2;
RETURN v_name;
END;
--調用出參預存程序
DECLARE
v_name student.sname%type;
BEGIN
DBMS_OUTPUT.put_line('在PL/SQL中列印的結果:'||stu_proc(v_name));
END;
4、出入參預存程序的調用
--建立出入參預存程序
CREATE OR REPLACE FUNCTION stu_proc(v_id IN NUMBER, v_name OUT VARCHAR2) RETURN VARCHAR2 IS
BEGIN
--執行語句段
SELECT o.sname INTO v_name FROM student o where o.id=v_id;
RETURN v_name;
END;
--調用出入參預存程序
DECLARE
v_name VARCHAR2(20);
BEGIN
DBMS_OUTPUT.put_line('在PL/SQL中列印的結果:'||stu_proc(1, v_name));
END;