Rumah  >  Artikel  >  pangkalan data  >  Apakah struktur asas prosedur tersimpan Oracle termasuk?

Apakah struktur asas prosedur tersimpan Oracle termasuk?

青灯夜游
青灯夜游asal
2022-03-02 16:52:153914semak imbas

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.

Apakah struktur asas prosedur tersimpan Oracle termasuk?

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 ;
di mana parameter IN mewakili parameter input dan merupakan mod lalai parameter.

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 8: Output hasil pertanyaan, "||" digunakan untuk menyambung rentetan dalam pangkalan data

Baris 9-11: Lakukan pengendalian pengecualian

Sintaks prosedur tersimpan

(1) Operator

(2) PILIH KE DALAM PENYATA pernyataan Apakah struktur asas prosedur tersimpan Oracle termasuk?

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 sambil

LOOP
  IF 表达式 THEN
    EXIT;
  END IF
END LOOP;
c.untuk gelung

WHILE 表达式 LOOP
  dbms_output.put_line('haha');
END LOOP;
Tutorial yang disyorkan: "

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn