一、PL/SQL简介
PL/SQL 是 Procedure Language & Structured Query Language 的缩写。PL/SQL 是对 SQL 语言存储过程语言的扩展。
PL/SQL是一种高级数据库程序设计语言,该语言专门用于在各种环境下对ORACLE数据库进行访问。由 于该语言集成于数据库服务器中,所以PL/SQL代码可以对数据进行快速高效的处理。PL/SQL 是 ORACLE 系统的核心语言,现在 ORACLE 的许多部件都是由 PL/SQL 写成。
在 PL/SQL 中可以使用的 SQL 语句有: INSERT,UPDATE,DELETE,SELECT … INTO,COMMIT,ROLLBACK,SAVEPOINT。
提示:在 PL/SQL 中只能用 SQL 语句中的 DML 部分,不能用 DDL 部分,如果要在 PL/SQL 中使用 DDL(如 CREATE table 等)的话,只能以动态的方式来使用。
二、PL/SQL块
1.结构:
PL/SQL 程序由三个块组成,即声明部分、执行部分、异常处理部分
DECLARE
/* 声明部分: 在此声明 PL/SQL 用到的变量,类型及游标,以及局部的存储过程和函数 */
BEGIN
/* 执行部分: 过程及 SQL 语句 , 即程序的主要部分 */
EXCEPTION
/* 执行异常部分: 错误处理 */
END;
其中 执行部分是必须的。
2.分类:
PL/SQL 块可以分为三类:
1. 无名块:动态构造,只能执行一次。
2. 子程序:存储在数据库中的存储过程、函数及包等。当在数据库上建立好后可以在其它程序中调用它 们。
3. 触发器:当数据库发生操作时,会触发一些事件,从而自动执行相应的程序。
3.标识符:
PL/SQL 程序设计中的标识符定义与 SQL 的标识符定义的要求相同。
4.变量类型
记录类型
定义:
记录类型是把逻辑相关的数据作为一个单元存储起来,称作 PL/SQL RECORD 的域(FIELD),其作用是存放互不相同但逻辑相关的信息。
格式:
TYPE record_type IS RECORD(
Field1 type1 [NOT NULL] [:= exp1 ],
Field2 type2 [NOT NULL] [:= exp2 ],
. . . . . .
Fieldn typen [NOT NULL] [:= expn ] ) ;
实例:
declare
type test_rec is record(
l_name varchar2(30),
d_id number(4));
v_emp test_rec;
begin
select last_name,department_id into v_emp
from employees
where employee_id = 200;
dbms_output.put_line(v_emp.l_name || ', '|| v_emp.d_id);
end;
提示:
1) DBMS_OUTPUT.PUT_LINE 过程的功能类似于 Java 中的 System.out.println() 直接将输出结果送到标准输出中.
2) 在使用上述过程之前必须将 SQL * PLUS 的环境参数 SERVEROUTPUT 设置为 ON, 否则将看不到输出结果: set serveroutput on
使用%TYPE
定义:定义一个变量,其数据类型与已经定义的某个数据变量的类型相同,或者与数据库表的某个列的数据类型 相同,这时可以使用%TYPE。
好处:所引用的数据库列的数据类型可以不必知道;所引用的数据库列的数据类型可以实时改变。
实例:
declare
type test_rec is record(
l_name employees.last_name%type,
d_id employees.department_id%type);
v_emp test_rec;
begin
select last_name,department_id into v_emp
from employees
where employee_id = 200;
dbms_output.put_line(v_emp.l_name || ', '|| v_emp.d_id);
end;
使用%ROWTYPE
定义:PL/SQL 提供%ROWTYPE 操作符, 返回一个记录类型, 其数据类型和数据库表的数据结构相一致。
好处:所引用的数据库中列的个数和数据类型可以不必知道;所引用的数据库中列的个数和数据类型可以实时改变。
实例:
declare
v_emp employees%rowtype;
begin
select * into v_emp
from employees where employee_id = 200;
dbms_output.put_line(v_emp.last_name||', '||v_emp.department_id);
end;
5.流程控制语句
条件语句——if:
格式1: 格式3:
IF <布尔表达式> IF <布尔表达式>
THEN PL/SQL 和 SQL 语句; THEN PL/SQL 和 SQL 语句;
END IF; ELSIF < 其它布尔表达式>
THEN 其它语句;
格式2: ELSIF < 其它布尔表达式>
IF <布尔表达式> THEN 其它语句;
THEN PL/SQL 和 SQL 语句; ELSE 其它语句;
ELSE 其它语句; END IF;
END IF;
提示: ELSIF 不能写成 ELSEIF
条件语句——case表达式:
格式:
CASE selector
WHEN expression1 THEN result1
WHEN expression2 THEN result2
WHEN expressionN THEN resultN
[ ELSE resultN+1]
END;
实例:
DECLARE
V_grade char(1) ;
V_appraisal VARCHAR2(20);
BEGIN
V_appraisal :=
CASE v_grade
WHEN ‘A’ THEN ‘Excellent’
WHEN ‘B’ THEN ‘Very Good’
WHEN ‘C’ THEN ‘Good’
ELSE ‘No such grade’
END;
DBMS_OUTPUT.PUT_LINE(‘Grade:‘||v_grade||’ Appraisal: ‘|| v_appraisal);
END;
循环语句——简单循环:
LOOP
要执行的语句;
EXIT WHEN <条件语句> ;/*条件满足,退出循环语句*/
END LOOP;
循环语句——WHILE循环(比前一种好用):
WHILE<布尔表达式> LOOP
要执行的语句;
END LOOP;
循环语句——数字式循环:
FOR 循环计数器 IN [ REVERSE ] 下限 .. 上限 LOOP
要执行的语句;
END LOOP;
注意:每循环一次,循环变量自动加 1;使用关键字 REVERSE,循环变量自动减 1。跟在 IN REVERSE 后面的数字必 须是从小到大的顺序,而且必须是整数,不能是变量或表达式。可以使用 EXIT 退出循环。
顺序语句——标号和GOTO语句:
PL/SQL 中 GOTO 语句是无条件跳转到指定的标号去的意思,一般用来跳出循环语句。语法如下:
GOTO label;
. . . . . .