学习目标:
1、掌握PL/SQL函数的定义和使用
2、掌握PL/SQL视图的定义和使用
学习过程:
一、函数Function
1、定义函数
函数的功能和在java封装一个方法的作用一样的,你可以把一些常用的功能封装起来,方便调用,函数是可以理解为有返回值的命名的 PL/SQL 子程序。创建函数的语法:
CREATE [OR REPLACE] FUNCTION
RETURN
[local declarations]
BEGIN
Executable Statements;
RETURN result;
EXCEPTION
Exception handlers;
END;
示例如下:
--10元以下返回廉价品,10~30大众品,30元以上奢侈品
create or replace function
chacash(cash GOODS.CASH%TYPE)
return varchar2
as
--这里可以定义函数的局部变量
begin
if cash<10 then
return '廉价品';
elsif cash between 10 and 30 then
return '大众品';
else
return '奢侈品';
end if;
end;
2、调用函数
自定义的函数和系统提供的函数的调用是一样的。示例如下:
select goods_name ,cash, chacash(cash) from goods
二、视图View
数据库中的视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。
视图就是一个虚表或者说就是一张逻辑表,那么定义视图有什么好处呢?
- 提高开发效率
- 提高运行效率
- 提高安全性
1、新建视图
create or replace view
my_view
as
select goods_name as gname,type_name as tt,chacash(cash) as bb
from goods g,goods_types t where g.type_id=t.type_id
2、使用视图
使用视图更简单,你可以当视图是一张实体表一样调用就可以了,但是视图一般用于查询,而不是使用增删改等操作。
select * from my_view