Oracle ialah sistem pangkalan data yang digunakan secara meluas, dan prosedur tersimpan ialah cara yang cekap untuk memproses data. Ia boleh memisahkan logik pemprosesan data dan logik perniagaan, dengan berkesan meningkatkan prestasi dan keselamatan sistem pangkalan data. Apabila menggunakan prosedur tersimpan Oracle, kita mungkin perlu mengembalikan beberapa data atau nilai. Nilai pulangan prosedur tersimpan Oracle akan dibincangkan di bawah.
Prosedur tersimpan Oracle menyokong berbilang jenis nilai pulangan, seperti integer, aksara, tarikh, dsb. Jenis nilai pulangan khusus perlu ditentukan berdasarkan keperluan perniagaan tertentu. Berikut mengambil pertanyaan tentang gaji bulanan pekerja sebagai contoh untuk menggambarkan cara menggunakan prosedur tersimpan Oracle untuk mengembalikan jenis data berangka.
BUAT ATAU GANTIKAN PROSEDUR EMP_GAJI
(
in_emp_id DALAM NOMBOR,
keluar_gaji KELUAR NOMBOR
)
ADALAH
BERMULA
Gaji keluar MULAI pekerja WHERE employee_id = in_emp_id;
END EMP_GAJI;
Prosedur tersimpan di atas memasukkan nombor pekerja melalui in_emp_id, dan kemudian mengembalikan gaji bulanan pekerja melalui out_gaji. Prosedur tersimpan mengisytiharkan dua parameter, in_emp_id ialah parameter input dan out_salary ialah parameter output. Pernyataan SELECT digunakan dalam prosedur tersimpan untuk menanyakan keputusan, dan keputusan pertanyaan diberikan kepada parameter output out_salary.
Apabila membangunkan prosedur tersimpan, kemungkinan ralat harus diambil kira, seperti parameter input kosong atau hasil pertanyaan kosong. Dalam prosedur tersimpan, ralat ini boleh dikendalikan dengan baik menggunakan pernyataan EXCEPTION atau prosedur RAISE_APPLICATION_ERROR.
BUAT ATAU GANTIKAN PROSEDUR EMP_GAJI
(
in_emp_id DALAM NOMBOR,
keluar_gaji KELUAR NOMBOR
)
ADALAH
emp_id NUMBER(18,2>); BEGIN
PILIH gaji KE DALAM emp_gaji DARIPADA pekerja WHERE employee_id = in_emp_id;
JIKA emp_gaji BATAL MAKA
RAISE_APPLICATION_ERROR(-20000, 'The employee salary is null.');
keluar_gaji := emp_gaji;
EXCTION🎜> BILA ORANG LAIN MAKA
RAISE_APPLICATION_ERROR(-20001, 'The employee salary could not be retrieved.');
Prosedur tersimpan di atas menambah pernyataan untuk menentukan sama ada emp_gaji kosong semasa membuat pertanyaan. Jika emp_salary kosong, mesej ralat tersuai akan dilemparkan. Jika ralat lain berlaku, mesej ralat lalai akan dilemparkan. Dalam pembangunan prosedur tersimpan, menggunakan mekanisme pengendalian ralat yang baik boleh meningkatkan keteguhan dan kebolehpercayaan program.
Set hasil dikembalikan oleh prosedur tersimpanCIPTA ATAU GANTIKAN query_blogs
( out_blogs OUT SYS_REFCUSOR
) SEBAGAI
BERMULA
OPEN out_blogs FOR SELECT * FROM blog;
END query_blogs;
Dalam kod ini, jenis SYS_REFCURSOR digunakan sebagai jenis parameter output, yang boleh digunakan untuk mengembalikan data tetapkan keputusan. Gunakan pernyataan OPEN dalam prosedur tersimpan untuk membuka set hasil, dan gunakan pernyataan pertanyaan SELECT untuk mendapatkan set hasil yang perlu dikembalikan.
Prosedur tersimpan adalah bahagian penting dalam pangkalan data Oracle. Apabila membangunkan prosedur tersimpan, anda perlu mempertimbangkan bukan sahaja pelaksanaan fungsi prosedur tersimpan, tetapi juga nilai pulangan yang munasabah dan pengendalian ralat. Pada masa yang sama, menggunakan prosedur tersimpan secara berkesan boleh meningkatkan prestasi dan keselamatan sistem pangkalan data, mengurangkan pertindihan kerja apabila menulis kod program yang sama, dan meningkatkan kecekapan keseluruhan aplikasi.
Atas ialah kandungan terperinci nilai pulangan prosedur tersimpan oracle. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!