PL/SQL规范、块、过程、函数、包、触发器
1.pl/sql规范
标识符号的命名规范
- 定义变量,用 v- 作为前缀 v-sal
2)定义常亮, 用 c- 作为前缀 c-rate - 定义游标,用 _cursor作为后缀 emp_cursor
- 定义例外,用 e_ 作为前缀 e_error
2.块(block)机构示意图
pl/sql 块有三部分构成,定义部分,执行部分,例外处理部分
declear
/*定义部分 --- 定义常量、变量、游标、例外、复杂属于类型*/
begin
/*执行部分 -- 要执行的pl/sql 语句 和 sql语句*/
exception
/*例外处理部分 --- 处理运行的各种错误*/
end;
其中执行部分是必须的,定义部分和例外处理部分是可选的.
实例1-只包含执行部分的pl/sql块
set serveroutput on; // on 和 off 打开与关闭内容是否输出
begin
dbms_output.put_line('hello world');
end;
dbms_output 是oracle提供的包,包里面包含一些过程,如put_line
实例2 - 包含定义部分和执行部分的pl/sql块
declare
v_name varchar2(5); --定义字符串变量
begin
select ename into v-ename form emp where empno=&no;
dbms_output.put_line('雇员名:' || v_name);
end;
/
&no 表示控制台输入,
into v_ename 将查出来的 ename 赋值给 v_ename
|| 类似于字符串拼接
declare
v_ename varchar2(5);
v_sal number(7,2);
begin
--执行部分
select ename,sal into v_ename,v_sal from emp where empno = &aa;
--在控制台显示
dbms_outln.put_line('用户名是:'||v_ename || '工资:' || v_sal);
end;
/
实例3-包含定义部分和执行部分和例外处理部分
为避免pl/sql程序的运行错误,提高健壮性,应该对可能的错误进行处理
(1) 比如在实例2中,如果输入了不存在的雇员号,应当做例外处理
(2) 有时候出现异常,希望用另外的逻辑处理
oracle 事先定义了一些异常,no_data_found 就是找不到数据的例外
declare
v_ename varchar2(5);
v_sal number(7, 2);
begin
--执行部分
select ename, sal into v_ename, v_sal from emp where empno = &aa;
--在控制台显示
dbms_outln.put_line('用户名是:' || v_ename || '工资:' || v_sal);
--异常处理
exception
when no_data_found then
dbms_output.put_line('编号输入有误');
end;
/
3.过程
-- 案例4
create procedure sp_pro3(spName, varchar, newSal number) is
begin
-- 执行部分,根据用户名修改工资
update emp set sal = newSal where ename == spName;
end;
/
-- 调用存储过程 exec 或者 call
exec sp_pro3('jack',9899);
4.函数
用于返回特定的数据,当建立函数时,在函数头部必须包含return子句,而在函数体内必须包含return 语句返回的数据
--输入雇员姓名,返回该雇员的信息
create function sp_fun2(spName varchar2) return number is
yearSal number(7, 2); -- 七位数两位小数
begin
-- 执行部分
select sal * 12 + nvl(comm, 0) * 12 into yearSal from emp where ename = spName;
return yearSal;
end;
/
在sqlplus 中调用函数:
sql>val income number
sql>call sp_cun2('jack') into:income
sql>print income
5.包
(1) 使用 create package 来创建包
create package sp_package is
procedure update_sal(name varchar2, newsal number);
function annual_income(name varchar2) return number;
end;
/
包的规范只包含了过程和函数的说明,但是没有过程和函数实现。
包体用于实现包规范
在pl/sql packages 里查看
(2) 建立包体使用 create package body 命令
-- 给 包sp_package 实现包体
create package body sp_package is
procedure update_sal(name varchar2, newsal number) is
begin
update emp set sal = newsal where ename = name;
end;
function annual_income(name varchar2) return number is
annual_salary number;
begin
select * sal * 12 + nvl(comm, 0)
into annual_salary
from emp
where ename = name;
return annual_salary;
end;
end;
然后就可以调用了:
sql> exec sp_paackage.update_sal('jack',200);
当调用包的过程或是函数时,在过程和函数前需要带有包名,如果要访问其他方案的包,还需要在包名前加方案名。
如:
SQL> call sp_package.update_sal('jack',200)
6.触发器
触发器是指隐含的执行的存储过程。当定义触发器时,必须要指定触发的事件和触发的操作,常用的触发事件包括insert,update,delete语句,而触发的操作实际就是一个 pl/sql块.
可以使用 create trigger 来建立触发器。
可以用来维护数据库的安全和一致性。
PL/SQL规范、块、过程、函数、包、触发器的更多相关文章
- Oracle基础(五)pl/sql进阶(分页过程)
编写分页过程 通过pl/sql实现分页过程,再该过程中由简单到难一步步深入,目的在于通过该案例熟悉pl/sql的各种存储过程,包,游标.怎样在java中调用等内容的学习. 1.无返回值 ...
- SQLPLUS执行PL/SQL语句块
1.首先登录Oracle HR schema: 2.对于PL/SQL程序,分号表示语句的结束:而使用 "." 号表示整个语句块的结束,也可以省略.按回车键后,该语句块不会执行,即 ...
- 同样的一句SQL语句在pl/sql 代码块中count 没有数据,但是直接用SQl 执行却可以count 得到结果
pl/sql 代码块: SELECT count(distinct t2.so_nbr) INTO v_count2 FROM KFGL_YW_STEP_qd t2 WHERE t2.partitio ...
- PL/SQL编程-块编程
(1). 简单分类 |————过程(存储过程) | ...
- PL/SQL之存储过程和函数
1.创建存储过程 .1语法: CREATE[OR REPLACE] PROCEDURE [schema.] procedure_name[(argument[{IN|OUT|IN OUT}] data ...
- oracle 中使用 pl/sql代码块
1.写匿名块,输入三角形三个表的长度.在控制台打印三角形的面积. declare -- (p=(a+b+c)/2) --声明三角形的面积 三条边 的 v_a number (10,2):=&n ...
- oracle pl/sql远程连接过程
之前没用过oracle,现在公司用到就记录下安装过程吧.安装PL/SQL工具,安装oracle11G工具.打开PL/SQL 进行配置.
- pl/sql基础知识—过程快速入门
n 过程 过程用于执行特定的操作,当建立过程时,既可以指定输入参数(in),也可以指定输出参数(out),通过在过程中使用输入参数,可以将数据传递到执行部分:通过使用输出参数可以将执行部分的数据传递 ...
- PL/SQL学习笔记之函数
一:函数 函数与过程的最大不同就是,函数有返回值.适用于需要返回结果的场景. 二:创建函数 CREATE [OR REPLACE] FUNCTION function_name [(parameter ...
随机推荐
- unity 热更新方案ILRuntime
https://github.com/meta-42/ILRuntime 教程 https://ourpalm.github.io/ILRuntime/public/v1/guide/index.ht ...
- 我们能用canvas做什么?
什么是Canvas? Canvas元素是HTML5的一部分,允许脚本语言动态渲染位图像.Canvas由一个可绘制地区HTML代码中的属性定义决定高度和宽度.JavaScript代码可以访问该地区,通过 ...
- python unix时间戳
这是第一次用着python感到怒了,从datetime转化到timestamp数值居然没有直接的函数 直接获取当前时间戳倒是方便: import time timestamp = time.time( ...
- python数据类型(集合)
一.集合概念 集合是一个数学概念:由一个或多个确定的元素所构成的整体叫做集合. 集合中的元素三个特征: 确定性(元素必须可hash) 互异性(去重)——将一个列表变为集合,就自动去重了 无序性(集合中 ...
- 人工智能(AI)
一.人工智能的核心——机器学习 人工智能是一个很大的圈子,但人工智能的基础是机器学习. 机器学习是什么? 其实就是人告诉机器想做什么事情,并且给它一堆数据让它模仿着去做. 机器学习需要什么? 算法.数 ...
- 1094 FBI树
1094 FBI树 2004年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题目描述 Description 我们可以把由“ ...
- html和css命名-望文生义
HTML+CSS命名规则 在一个内容较多的HTML页面中,需要设计许多不同的框架,再为这些不同的框架及内容进行分类,给予相应的名称,从而使得网页结构更加清晰,也为工作提供了方便.许多新手朋友在设计一个 ...
- C++基础--结构体声名
struct是一种数据结构,当需要存储的相关数据为一个集合时,struct是很好的选择;例如,当存储student,学生的学号, 名字,年龄,身高,就构成了一个集合,用stuct声名为: typede ...
- C++基础--指针,&的用法
#include "stdafx.h" #include <stdio.h> #include <string.h> int main() { ] = {, ...
- 五款app原型设计工具对比
五款app原型设计工具对比 Proto.io, Pixate, Origami, Framer & Form 本文由Panblack 翻译,原文作者 Tes Mat 我用五款“高保真”原型设计 ...