Prosedur tersimpan dalam pangkalan data Oracle ialah atur cara PL/SQL yang dipratentukan yang boleh dilaksanakan berbilang kali tanpa menulis semula. Prosedur tersimpan boleh digunakan dengan pangkalan data Oracle untuk mencapai fungsi yang lebih cekap seperti pengurusan data, kawalan akses, transformasi data, dsb.
Dalam aplikasi praktikal, kita biasanya perlu mengembalikan nilai dalam prosedur tersimpan untuk pemprosesan selanjutnya, seperti menyemak keputusan pelaksanaan program, mendapatkan hasil pelaksanaan, dsb. Oleh itu, artikel ini akan memperkenalkan kandungan berkaitan nilai pulangan dalam prosedur tersimpan Oracle, termasuk cara menentukan nilai pulangan, cara mendapatkan nilai pulangan, dsb.
1. Tentukan nilai pulangan prosedur yang disimpan
1 Gunakan parameter OUT
Prosedur yang disimpan Oracle boleh mengembalikan nilai melalui parameter OUT. Parameter OUT pada asasnya ialah jenis parameter prosedur tersimpan yang boleh diberikan nilai dalam prosedur tersimpan dan dikembalikan kepada pemanggil pada penghujung prosedur tersimpan. Apabila mentakrifkan prosedur tersimpan, anda boleh menetapkan jenis parameter kepada OUT, seperti ditunjukkan di bawah:
CREATE OR REPLACE PROCEDURE procedure_name(p_param1 IN type1, p_param2 OUT type2) IS BEGIN -- 存储过程主体 END;
Dalam kod di atas, p_param2 ialah parameter OUT dengan jenis2.
2. Gunakan nilai pulangan fungsi
Cara lain untuk menentukan nilai pulangan prosedur tersimpan ialah menggunakan fungsi. Fungsi dipanggil dalam prosedur tersimpan dan fungsi mengembalikan nilai sebagai hasil prosedur tersimpan, seperti yang ditunjukkan di bawah:
CREATE OR REPLACE FUNCTION function_name(p_param1 IN type1) RETURN type2 IS -- 函数主体 BEGIN RETURN result; END; CREATE OR REPLACE PROCEDURE procedure_name(p_param1 IN type1, p_result OUT type2) IS BEGIN p_result = function_name(p_param1); END;
Dalam kod di atas, prosedur tersimpan memanggil fungsi_nama fungsi dan menyimpan nilai pulangan di tengah pembolehubah p_result.
2. Dapatkan nilai pulangan prosedur tersimpan
1 Gunakan parameter OUT
Apabila memanggil prosedur tersimpan, anda boleh menggunakan parameter OUT sebagai nilai pulangan. untuk mendapatkan nilai pulangan prosedur tersimpan Hasil pelaksanaan adalah seperti berikut:
DECLARE v_result type2; -- 存储过程返回结果 BEGIN procedure_name(param1, v_result); DBMS_OUTPUT.PUT_LINE('result:' || v_result); END;
Dalam kod di atas, nama prosedur tersimpan menyimpan hasil pelaksanaan dalam pembolehubah v_result dan mencetak hasilnya melalui pernyataan output.
2. Gunakan nilai pulangan fungsi
Apabila memanggil prosedur tersimpan, anda boleh menggunakan pembolehubah untuk menyimpan nilai pulangan fungsi dan menggunakannya sebagai hasil pelaksanaan prosedur tersimpan, sebagai ditunjukkan di bawah:
DECLARE v_result type2; -- 存储过程返回结果 BEGIN v_result = function_name(param1); DBMS_OUTPUT.PUT_LINE('result:' || v_result); END;
Dalam kod di atas, nama function_prosedur yang disimpan menyimpan hasil pelaksanaan dalam v_result pembolehubah, dan mencetak hasilnya melalui pernyataan output.
Ringkasnya, prosedur tersimpan adalah teknologi pengaturcaraan pangkalan data yang sangat praktikal Dalam aplikasi praktikal, kita selalunya perlu mendapatkan hasil pelaksanaan daripada prosedur tersimpan untuk pemprosesan seterusnya. Artikel ini memperkenalkan dua kaedah untuk mentakrifkan nilai pulangan prosedur tersimpan dan cara mendapatkan keputusan Pembaca boleh memilih kaedah yang sepadan mengikut keperluan sebenar mereka.
Atas ialah kandungan terperinci nilai pulangan prosedur tersimpan oracle. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!