Struktur prosedur tersimpan Oracle mengandungi tiga bahagian: 1. Pengisytiharan proses; 2. Bahagian proses pelaksanaan; 3. Pengecualian prosedur tersimpan jika anda ingin meningkatkan toleransi kesalahan skrip dan kemudahan penyahpepijatan hanya tulis pengendalian pengecualian.
Persekitaran pengendalian tutorial ini: sistem Windows 7, versi Oracle 11g, komputer Dell G3.
Apakah prosedur tersimpan , satu set pernyataan SQL untuk melengkapkan fungsi tertentu disimpan dalam pangkalan data Selepas penyusunan pertama, ia tidak perlu dikompilasi semula apabila dipanggil semula . Pengguna menentukan nama prosedur tersimpan dan memberikan parameter (jika prosedur tersimpan mempunyai parameter) ) untuk memanggil prosedur tersimpan. Ringkasnya, ia adalah pernyataan SQL yang melakukan satu perkara secara khusus.
boleh dipanggil oleh pangkalan data itu sendiri atau oleh program java.
Prosedur tersimpan ialah prosedur dalam pangkalan data oracle.
Struktur prosedur tersimpan
(1) Struktur asas
Prosedur tersimpan Oracle mengandungi tiga bahagian : Pengisytiharan proses, bahagian proses pelaksanaan, pengecualian prosedur tersimpan (boleh ditulis atau tidak, untuk meningkatkan toleransi kesalahan skrip dan kemudahan penyahpepijatan, tulis pengendalian pengecualian)
(2) Tiada parameter Prosedur penyimpanan(3 Prosedur tersimpan dengan parameter
/** name_procedure就是自己自定义的存储过程名 */ create or replace procedure name_procedure AS/IS 变量名1 数据类型; 变量名2 数据类型; BEGIN --要处理的业务逻辑 EXCEPTION --存储过程异常 END name_procedure;
Prosedur disimpan parameter biasa
Penyimpanan dengan parameter Proses dan tetapkan nilai/* age 类型为number 初始化为20; */ CREATE OR REPLACE PROCEDURE name_procedure (param1 TYPE) AS/IS name varchar(20); age number :=20; BEGIN --业务处理..... END ;
CREATE OR REPLACE PROCEDURE 存储过程名称( s_no in varchar, s_name out varchar, s_age number) AS total NUMBER := 0; BEGIN SELECT COUNT(1) INTO total FROM student s WHERE s.age=s_age; dbms_output.put_line('符合该年龄的学生有'||total||'人'); EXCEPTION WHEN too_many_rows THEN DBMS_OUTPUT.PUT_LINE('返回值多于1行'); END
OUT mewakili parameter nilai pulangan, dan jenis boleh menggunakan mana-mana jenis undang-undang dalam Oracle.
Parameter yang ditakrifkan dalam mod OUT hanya boleh diberikan dalam badan proses, yang bermaksud bahawa parameter boleh menghantar nilai tertentu kembali kepada proses panggilan
IN OUT bermaksud parameter boleh menghantar nilai kepada proses, atau nilai tertentu boleh dipadamkan
Baris 7: Pernyataan pertanyaan, menggunakan parameter s_age sebagai keadaan penapis, KE dalam kata kunci, tetapkan hasil yang ditemui kepada jumlah pembolehubah.
Baris 9-11: Lakukan pengendalian pengecualian
Sintaks prosedur tersimpan
(1) Operator
(2) PILIH KE DALAM PENYATA pernyataan
Tetapkan hasil pertanyaan kepada satu pembolehubah atau berbilang pembolehubah
Keperluan: Hasilnya ialah 100 mata Nama, umur, tempat kelahiran pelajar
(3) Pilih pernyataan
CREATE OR REPLACE PROCEDURE DEMO_CDD1 IS s_name VARCHAR2; --学生名称 s_age NUMBER; --学生年龄 s_address VARCHAR2; --学生籍贯 BEGIN --给单个变量赋值 SELECT student_address INTO s_address FROM student where student_grade=100; --给多个变量赋值 SELECT student_name,student_age INTO s_name,s_age FROM student where student_grade=100; --输出成绩为100分的那个学生信息 dbms_output.put_line('姓名:'||s_name||',年龄:'||s_age||',籍贯:'||s_address); END
(4) Penyataan gelung
//if 后面一定要添加THEN 相当于Java中的 大括号 IF s_sex=1 THEN dbms_output.put_line('这个学生是男生'); ELSE IF THEN dbms_output.put_line('这个学生是女生'); ELSE dbms_output.put_line('这个学生性别错误'); END IF
a.Gelung asas
b.gelung sambilLOOP IF 表达式 THEN EXIT; END IF END LOOP;
WHILE 表达式 LOOP dbms_output.put_line('haha'); END LOOP;
Tutorial Oracle
》//a 1 到 20 范围 FOR a in 10 .. 20 LOOP dbms_output.put_line('value of a: ' || a); END LOOP;
Atas ialah kandungan terperinci Apakah struktur asas prosedur tersimpan Oracle termasuk?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!