n  介绍

块(block)是pl/sql的基本成型单元,编写pl/sql程序实际上就是编写pl/sql块。要完成相对简单的应用功能,可能只需要编写一个pl/sql块;但是如果要想实现复杂的功能,可能需要在一个pl/sql块中嵌套其它的pl/sql块。、

n  块结构示意图

pl/sql块由三个部分构成:定义部分、执行部分、例外处理部分,如下所示:

 
   

n  案例1--只包括执行部分的pl/sql块。

案例:输出hello,world

☞相关说明:

dbms_output是oracle所提供的包(类似java的开发包),该包包含一些过程,put_line就是dbms_output包的一个过程。

SQL>
set serveroutput on;  //打开控制台显示,默认不输出,需要执行此命令才会输出显示

SQL>

SQL>
begin

2   
dbms_output.put_line('hello,world');

3   
end;

4  /

hello,world

PL/SQL
procedure successfully completed

n  案例2--包括定义部分和执行部分的pl/sql块。

案例:根据用户输入的雇员编号,显示该雇员的名字

☞相关说明:

&
表示要接收从控制台输入的变量

‖表示把两个串拼接

declare  --定义变量的格式:变量名称  变量的类型

v_ename varchar2(8);

begin

select
ename into
v_ename from
emp where
empno=&empno;--把查询的ename值放入v_ename变量

---输出v_ename

dbms_output.put_line('雇员名是:'||v_ename);

end;

雇员名是:SMITH

PL/SQL
procedure successfully completed

将其改为过程

SQL>
create procedure pro3(in_empno number) is

2   
v_ename varchar2(8);

3   
begin

4     
select ename into v_ename from emp where empno=in_empno;

5     
dbms_output.put_line('雇员名是:'||v_ename);

6     
end;

7  /

Procedure
created

SQL>
exec pro3(7369);

雇员名是:SMITH

PL/SQL
procedure successfully completed

n  案例3--包括定义部分和执行部分和例外处理部分。

为了避免pl/sql程序的运行错误,提高pl/sql的健壮性,应该对可能的错误进行处理,这个很有必要:

①比如在案例2中,如果输入了不存在的雇员号,应当做例外处理

②有时出现异常,希望用另外的逻辑处理,比如:如果不存在就加入编号为1,名字为‘马大哈’这么一个人。

我们看看如何完成①的要求

相关说明:oracle事先预定义了一些例外,no_data_found就是找不到数据的例外。

SQL> declare

2   
v_ename varchar2(8);

3   
begin

4     
select ename into v_ename from emp where empno=&empno;

5     
dbms_output.put_line('雇员名是:'||v_ename);

6   
exception

7       when no_data_found then

8        
dbms_output.put_line('朋友,你输入的编号有误');

9   
end;

10  /

朋友,你输入的编号有误

PL/SQL procedure successfully
completed

对该案例的细节说明:这里我们涉及到异常处理,

异常处理的基本语法:

exception

when 异常的名称
then

//对异常进行处理的代码......

//对异常进行处理的代码......

when 异常的名称2
then

//对异常进行处理的代码......

end;

oracle提供的异常有:(参考pl/sql官方文档)大概23种

有时可以利用异常来进行业务处理。比如:如果不存在就加入编号为1,名字为‘马大哈’这么一个人。

SQL> declare

2   
v_ename varchar2(8);

3   
begin

4     
select ename into v_ename from emp where empno=&empno;

5     
dbms_output.put_line('雇员名是:'||v_ename);

6   
exception

7      
when no_data_found then

8        
dbms_output.put_line('朋友,你输入的编号有误!我帮你加入一条');

9        
insert into emp (empno,ename) values(1,'马大哈');

10   
end;

11  /

朋友,你输入的编号有误!我帮你加入一条

PL/SQL procedure successfully
completed

pl/sql基础知识—pl/sql块介绍的更多相关文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  2. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  3. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  4. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  5. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  6. [SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

    SQL 基础知识梳理(六)-  函数.谓词.CASE 表达式 目录 函数 谓词 CASE 表达式 一.函数 1.函数:输入某一值得到相应输出结果的功能,输入值称为“参数”,输出值称为“返回值”. 2. ...

  7. [SQL] SQL 基础知识梳理(七)- 集合运算

    SQL 基础知识梳理(七)- 集合运算 目录 表的加减法 联结(以列为单位) 一.表的加减法 1.集合:记录的集合(表.视图和查询的执行结果). 2.UNION(并集):表的加法 -- DDL:创建表 ...

  8. 常见SQL语句和SQL基础知识

    引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name   k ...

  9. [SQL基础教程]1-4 SQL 表的创建

    [SQL基础教程]1-4 SQL 表的创建 创建数据库 语法 CREATE DATABASE <数据库名称> // example CREATE DATABASE shop; 创建表 语法 ...

随机推荐

  1. android服务的bindService/startService

    1,高版本android已经不允许只通过action来bindService/startService,可以通过: intent.setPackage("XXXX"); 来指定服务 ...

  2. java基础之自定义单链表练习

    一.单链表 1.单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点的构成:元素(数据元素的映象) + 指针(指示后继元素存储位置), ...

  3. struts2-环境搭建-访问流程-配置详解-常量配置-类详解

    1 struts2概述 1.1 概念  1.2 struts2使用优势 自动封装参数 参数校验 结果的处理(转发|重定向) 国际化 显示等待页面 表单的防止重复提交 struts2具有更加先进的架构以 ...

  4. 有趣的纯CSS实现动态晴阴雨雪

    我们先来看看实现的效果吧 非常的美腻,对吧.这个是纯css,且单标签实现的哦~ 先贴完整代码,我们再来看看这个里面究竟有什么可以借鉴的知识点 <!DOCTYPE html> <htm ...

  5. SSM9-Redis的搭建

    1. Redis的安装 1.1. Redis的安装 Redis是c语言开发的. 安装redis需要c语言的编译环境.如果没有gcc需要在线安装.yum install gcc-c++ 安装步骤: 第一 ...

  6. git与github建立链接(将本次项目与网络GitHub同步)(二)

    第一步:我们需要先创建一个本地的版本库(其实也就是一个文件夹). 你可以直接右击新建文件夹,也可以右击打开Git bash命令行窗口通过命令来创建. 现在我通过命令行在桌面新建一个TEST文件夹(你也 ...

  7. @import vs #import - iOS 7

    It's a new feature called Modules or "semantic import". There's more info in the WWDC 2013 ...

  8. 使用 git 及 github

    1.github 开户.创建项目 2.以下是本地操作: #初始本地库 git init#设置git的全局邮箱和用户名git config --global user.email "<e ...

  9. centos 安装nginx + 多个tomcat负载均衡

    今天在centos上安装了两个tomcat和nginx,进行配置.今天记录的只是最基本的实现测试.(不包含使用redis进行session共享) Nginx 是一款轻量级的Web 服务器/反向代理服务 ...

  10. 【CodeVS】2750 心系南方灾区

    2750 心系南方灾区 时间限制: 1 s 空间限制: 2000 KB 题目等级 : 青铜 Bronze 题目描述 Description 现在我国南方正在承受百年不遇的大雪.冻雨灾害.北京市已经开始 ...