PL/SQL块

1.简介

Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询与Oracle自身过程控制为一体的强大语言,PL/SQL不但支持更多的数据类型,拥有自身的变量声明、赋值语句,而且还有条件、循环等流程控制语句。过程控制结构与SQL数据处理能力无缝的结合形成了强大的编程语言,可以创建过程和函数以及程序包。

PL/SQL是一种块结构的语言,它将一组语句放在一个块中,一次性发送给服务器,PL/SQL引擎分析收到PL/SQL语句块中的内容,把其中的过程控制语句由PL/SQL引擎自身去执行,把PL/SQL块中的SQL语句交给服务器的SQL语句执行器执行。如图所示:


image.png
2.语法结构

PL/SQL 块是构成 PL/SQL 程序的基本单元
将逻辑上相关的声明和语句组合在一起
PL/SQL 分为三个部分,声明部分、可执行部分和异常处理部分

[DECLARE 
declarations] --声明部分
BEGIN
executable statements--可执行部分
[EXCEPTION 
handlers]--异常处理部分
END;

PL/SQL块可以分为三类:
1.无名块或匿名块(anonymous):动态构造,只能执行一次,可调用其它程序,但不能被其它程序调用。
2.命名块(named):是带有名称的匿名块,这个名称就是标签。
3.子程序(subprogram):存储在数据库中的存储过程、函数等。当在数据库上建立好后可以在其它程序中调用它们。
4.触发器(Trigger):当数据库发生操作时,会触发一些事件,从而自动执行相应的程序。
5.程序包(package):存储在数据库中的一组子程序、变量定义。在包中的子程序可以被其它程序包或子程序调用。但如果声明的是局部子程序,则只能在定义该局部子程序的块中调用该局部子程序。
例如

DECLARE
bid int := '&id';  ①
--v_isbn iweb_tbl_book.isbn%TYPE;②
--v_title iweb_tbl_book.title%TYPE;③
--v_author iweb_tbl_book.author%TYPE;
v_book iweb_tbl_book%ROWTYPE;④
BEGIN
select * into v_book 
from iweb_tbl_book
where id = bid;
--输出结果
dbms_output.put_line('isbn:' || v_book.isbn);⑤
dbms_output.put_line('title:' || v_book.title);⑥
dbms_output.put_line('author:'|| v_book.author);
dbms_output.put_line('pagenum:'|| v_book.pagenum);
END;

--①'&id'表示从外部录入数据ID,变量声明赋值用 :=
也可以使用select…into语句对变量sname赋值,要求查询的结果必须是一行,不能是多行或者没有记录

SELECT ename INTO sname FROM emp WHERE empno=7934;

--②%iweb_tbl_book.title%TYPE指向表中书名列的属性,好处是不需要自己再赋予属性了
--③给变量命名时一般遵循规则v_name,给常量命名时遵循c_name
--④%ROWTYPE - 提供表示表中一行的记录类型
--⑤输出结果dbms_output.put_line()
--⑥ || 用来分隔变量和字符串

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • PL/SQL 这是对Oracle-SQL知识点详细介绍的文章系列,其他文章如下: Oracle-SQL系列知识点(...
    GuaKin_Huang阅读 7,283评论 0 14
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,785评论 18 399
  • 如果不是为了应付时间逼宫 如果不是为了本性和欲望 如果不是为了相互取暖 人们其实不用结婚的 毕竟在这个牵个手就能上...
    幻梦邪魂阅读 464评论 4 1
  • 曾经我来过 来的时候遇到如花的你 如今我走了 走的时候乞求温柔的你 现在的你我 怎样去面对无知的过错 背叛让彼此伤...
    念江子阅读 176评论 4 3
  • 用心生活,处处是惊喜! 用心陪伴孩子成长,就是一场自我修炼的过程!或许,你不认同我,但是,我相信在将来某一天,你终...
    lily的姐姐阅读 206评论 0 0