PL SQL基本内容(原创)
本节介绍PL SQL的基本内容
本节所举示例数据来源oracle用户scott下的emp表和dept表,数据如下:
一、plsql简介:
1、概念:procedural language,过程化sql语言,是面向过程的语言,在普通sql的基础上增加了编程语言的特点。PL/SQL的基本单元是块。
2、块的介绍:
(1)基本结构:
DECLARE
(声明部分)
BEGIN
(执行部分)
EXCEPTION
(异常处理部分)
END(结束标记)
红色部分为必须部分,不可缺少
3、块的分类:
(1)匿名块:只会执行一次,被动态构造。
(2)子程序:存储在数据库中的存储过程、函数、包等,完成一定功能,可以在其他程序上调用他们。
(3)当数据库发生操作时,会触发事件自动执行相应的程序。
(注:存储过程、触发器会在后面的博客中详细说明)
二、标识符:
1、概念:不能超过30个字符,第一个字符必须为字母,不能用减号“-”,并且不区分大小写。
2、变量的命名:为提高代码可读性,建议遵从以下规则:
(1)程序变量:v_variablename
(2)程序常量:v_constantname
(3)游标变量:cursorname_cursor
(4)异常标识:e_exceptionname
(5)记录类型:recordname_record
Example:查询雇员编号为7788的员工的工资雇员日期以及工资涨500后的结果。
DECLARE
v_name VARCHAR2(20);
v_sal NUMBER(7,2);
v_hiredate DATE;
c_addsal NUMBER(7,2):=500;
v_newsal NUMBER(7,2);
BEGIN
SELECT ename,sal,hiredate
INTO v_name,v_sal,v_hiredate FROM emp WHERE empno=7788;
v_newsal := v_sal + c_addsal;
DBMS_OUTPUT.PUT_LINE(v_name||'的工资为'||v_sal||'雇员日期为'||v_hiredate||'工资涨后为'||v_newsal);
EXCEPTION
WHEN NO_DATA_FOUND THEN
DBMS_OUTPUT.PUT_LINE('没有员工数据');
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE(SQLERRM);
END;
上面是一个简单的匿名块,只用来执行一次,DBMS_OUTPUT.PUTLINE()用来做打印输出,NO_DATA_FOUND是没有查找到数据,SQLERRM错误信息。
三、记录型变量和引用型变量:
1、引用型变量:
指数据类型和已经定义或数据库中某一列的数据类型相同:
Example:v_name emp.ename%TYPE;这里定义的变量v_name和emp表中的ename数据类型相同。
2、记录型变量:
返回一个记录类型,和数据库表的数据类型一致。
Example:emp_record emp%rowtype;emp_record和数据库表emp的数据类型相同,所以可以emp_record.ename
下面各举一个实例:
Example1:打印输出7788的员工工资
DECLARE
v_name emp.ename%TYPE;
v_sal emp.sal%TYPE;
BEGIN
SELECT ename,sal
INTO v_name,v_sal FROM emp WHERE empno=7788;
DBMS_OUTPUT.PUT_LINE(v_name||'的工资是'||v_sal);
END;
Example2:打印输出7788的员工工资,使用记录型变量
DECLARE
emp_record emp%ROWTYPE;
BEGIN
SELECT * INTO emp_record FROM emp WHERE empno=7788;
DBMS_OUTPUT.PUT_LINE(emp_record.ename||'的工资是'||emp_record.sal);
END;
四、流程控制语句:
1、概念:分为3类
(1)条件控制语句:IF语句,CASE语句
(2)循环语句:LOOP语句
(3)顺序语句:GOTO语句、NULL语句
Example1:根据输入的值判断等级并输出
DECLARE
v_level CHAR(1):='&LEVEL';
BEGIN
IF v_level='A' THEN
DBMS_OUTPUT.PUT_LINE('优秀');
ELSIF v_level='B' THEN
DBMS_OUTPUT.PUT_LINE('良好');
ELSIF v_level='C' THEN
DBMS_OUTPUT.PUT_LINE('一般');
ELSE
DBMS_OUTPUT.PUT_LINE('输入有误');
END IF;
END;
这里用到了&这个符号,用来给变量进行赋值,会弹出第二个图所示的窗口让user赋值,最后给出结果,
其中用到的ELSIF 和ELSE可根据情况不要,注意这里ELSIF 不是ELSEIF.
Example2:根据输入的值判断等级并输出
DECLARE
v_level CHAR(1):='&LEVEL';
BEGIN
CASE v_level
WHEN 'A' THEN
DBMS_OUTPUT.PUT_LINE('优秀');
WHEN 'B' THEN
DBMS_OUTPUT.PUT_LINE('良好');
WHEN 'C' THEN
DBMS_OUTPUT.PUT_LINE('一般');
ELSE
DBMS_OUTPUT.PUT_LINE('输入有误');
END CASE;
END;
这里用了CASE语句,他可以和IF语句相互转换,喜欢用哪个看个人爱好。
Example3:打印输出1,2,3,4,5
DECLARE
v_num INT:=1;
BEGIN
LOOP
DBMS_OUTPUT.PUT_LINE(v_num);
EXIT WHEN v_num=5;
v_num :=v_num+1;
END LOOP;
END;
这里用了loop的基本循环。注意一定要有退出循环的条件,不然就会无限循环变为死循环。这里用到了EXIT WHEN语句,是有条件的退出循环,
还有一个EXIT用来直接退出循环不加条件,另外在oracle 11g中有一个新特性,CONTINUE和CONTINUE WHEN ,其中CONTINUE用于跳过当
前循环,CONTINUE WEHN 用于有条件的跳过当前循环,实例如下:
Example3.2:打印输出1,2,3,5
DECLARE
v_num INT:=0;
BEGIN
WHILE v_num<5 LOOP
v_num :=v_num+1;
CONTINUE WHEN v_num=4;
DBMS_OUTPUT.PUT_LINE(v_num);
END LOOP;
END;
这里可以看到当数值为4是跳出了这轮循环并没有输出4.
Example4:打印输出1,2,3,4,5
DECLARE
v_num INT:=1;
BEGIN
WHILE v_num<=5 LOOP
DBMS_OUTPUT.PUT_LINE(v_num);
v_num :=v_num+1;
END LOOP;
END;
这里用了while循环,和上个例子相比,只是将退出循环的条件从EXIT WHEN 改为了WHILE,没有特别大的不同,用法看个人喜好。
Example5:倒序打印5,4,3,2,1
BEGIN
FOR i IN REVERSE 1..5 LOOP
DBMS_OUTPUT.PUT_LINE(i);
END LOOP;
END;
这里用了For循环用来控制循环次数,也是起到一个退出循环的条件,但是更加精确次数,其中的REVERSE起的是倒序的作用,也可以去掉变为正序。
Example6:根据输入的值判断等级并输出,如果输入D则什么都不做
DECLARE
v_level CHAR(1):='&LEVEL';
BEGIN
CASE v_level
WHEN 'D' THEN
GOTO the_next;
WHEN 'A' THEN
DBMS_OUTPUT.PUT_LINE('优秀');
WHEN 'B' THEN
DBMS_OUTPUT.PUT_LINE('良好');
WHEN 'C' THEN
DBMS_OUTPUT.PUT_LINE('一般');
END CASE;
<<the_next>>
null;
END;
这里用到了GOTO,无条件跳转到同一个程序的标签,但不建议在任何编程语言中使用它,它会使程序难以跟踪流程,难以维护。
同时用到了null语句,顾名思义,不做任何事情,其意义所在,是某些语句变得有意义,提高语句的可读性和完整性。
五、嵌套循环
1、概念:指在一个循环中嵌套另一个循环的语句,用于标记嵌套循环的叫标号,使用<<label_name>>表示。
Example:打印输出1x1到5x5的乘法口诀吧
BEGIN
<<outter>>
FOR i IN 1..5 LOOP
<<inner>>
FOR j IN 1..5 LOOP
CONTINUE WHEN j>i;
DBMS_OUTPUT.PUT_LINE(i||'*'||j||'='||i*j);
END LOOP inner;
END LOOP outter;
END;
用了2层嵌套循环,CONTINUE WHEN 做跳出当前循环的条件,<<inner>><<outter>>分别用于结束内层循环和外层循环。
至此,plsql的基本内容完毕,其中还有些存储过程和触发器会在后面分节做精细说明。
2018-08-15 15:26:17
PL SQL基本内容(原创)的更多相关文章
- 【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航
原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人 ...
- ORACLE PL/SQL编程详解
ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...
- [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)
原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...
- ORACLE PL/SQL编程之八:把触发器说透
原文:ORACLE PL/SQL编程之八:把触发器说透 ORACLE PL/SQL编程之八: 把触发器说透 大家一定要评论呀,感谢!光发表就花了我将近一个下午. 本篇主要内容如下: 8.1 触发器类型 ...
- [推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼、百战不殆)
原文:[推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不殆) [推荐]ORACLE PL/SQL编程之五: 异常错误处理(知已知彼.百战不殆) 继上三篇:ORACLE PL/S ...
- ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)
原文:ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!) ORACLE PL/SQL编程之六: 把过程与函数说透(穷追猛打,把根儿都拔起!) 继上篇:ORACLE P ...
- [推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)
原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ...
- [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到)
原文:[推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]ORACLE PL/SQL编程之四: 把游标说透(不怕做不到,只怕想不到) 继上两篇:ORACLE PL ...
- [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)
原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下 ...
随机推荐
- 我所遭遇过的游戏中间件--Havok
我所遭遇过的游戏中间件--Havok Havok是我接触的第一款游戏中间件,那是在五,六年前,我刚刚毕业,对游戏开发还是个菜鸟.我记得先是对游戏场景中的地形和其他静态物体生成刚体,然后做角色的Ragd ...
- JSTORM使用笔记
安装部署 zeromq 简单快速的传输层框架,安装如下: wget http://download.zeromq.org/zeromq-2.1.7.tar.gztar zxf zeromq-2.1.7 ...
- Horspool 字符串匹配算法
Horspool 字符串匹配算法对Boyer-Moore算法的简化算法. Horspool 算法是一种基于后缀匹配的方法,是一种“跳跃式”匹配算法,具有sub-linear亚线性时间复杂度. Hors ...
- Minimum Depth of Binary Tree leetcode java
题目: Given a binary tree, find its minimum depth. The minimum depth is the number of nodes along the ...
- .Net应用程序打包部署总结
编译源代码并完成测试以后,开发过程其实并没有结束.在这个极端,需要把应用程序提供给用户.无论是ASP.NET应用程序,客户端应用程序还是 Compact Framework构建的应用程序,开发出来的软 ...
- web 实时通信的方法总结
1.Web端即时通讯技术 即时通讯技术简单的说就是实现这样一种功能:服务器端可以即时地将数据的更新或变化反应到客户端,例如消息即时推送等功能都是通过这种技术实现的. 但是在Web中,由于浏览器的限制, ...
- report studio 交叉表占比
要求如下图的百分比 新建数据项:[产品数]/total ( [产品数] for report )
- 修改上一篇文章的node.js代码,支持调用自定义页面
上一篇文章所有请求只能调用index.html,现在做个改造,允许调用自定义页面 服务端 app.js var app = require('http').createServer(handler) ...
- java实现内部排序算法
冒泡排序 public class BubbleSort{ public static int[] asc(int[] a){ int item; for (int i = 0; i < a.l ...
- 算法笔记_174:历届试题 地宫取宝(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明 ...