不得不会的Oracle数据库知识点(四)

简介: 不得不会的Oracle数据库知识点(四)

一.使用PL/SQL


可用于创建存储过程,触发器,程序包,给SQL语句的执行添加程序逻辑。

支持SQL,在PL/SQL中可以使用:

数据操纵命令

事务控制命令

游标控制

SQL函数和SQL运算符

支持面向对象编程(OOP)

可移植性

更佳的性能,PL/SQL经过编译执行

分为三个部分:声明部分,可执行部分和异常处理部分

[declare
declarations]
begin
executable statements
[exception
handlers]
end;
复制代码

打开输出

set serverout on;
复制代码

二、游标管理


游标类型:隐式游标,显式游标,REF游标

REF游标用于处理运行时才能确定的动态SQL查询的结果

==========隐式游标==========

在PL/SQL中使用DML语句时自动创建隐式游标

隐式游标自动声明、打开和关闭,其名为SQL

隐式游标的属性:

%found                       SQL语句影响实质后返回true

%notfound                 SQL语句没有影响实质后返回true

%rowcount                SQL语句影响的行数

%isopen            游标是否打开,始终为false

示例:

begin
update user_tbl set score=score+5;
if SQL%found then
         dbms_output.put_line('数据被更改: '||SQL%rowcount);
elsif sql%notfound then
         dbms_output.put_line('没有找到数据!');
end if;
if SQL%isopen then
         dbms_output.put_line('Open');
else
         dbms_output.put_line('Close');
end if;
end;
复制代码

==========显式游标==========

在PL/SQL的声明部分定义查询,该查询可以返回多行:

声明游标、打开游标、 从游标中取回数据、关闭游标

声明游标完成两个任务:

给游标命名

将一个查询与游标关联

cursor cursor_name is select statement;
复制代码

打开游标:

open cursor_name;
复制代码

取数据:  

fetch cursor_name into record_list;
复制代码

关闭游标:      

close cursor_name;
复制代码

显式游标的属性:

%found                      执行最后一条fetch语句成功返回行时为true

%notfound                 执行最后一条fetch语句未能返回行时为true

%rowcount                返回到目前为止游标提取的行数

%isopen            游标是否打开

示例:

带参的显式游标

declare
users user_tbl%rowtype;
cursor boys_cur(sexParam varchar2)
is select * from user_tbl where sex=sexParam;
begin
open boys_cur('&sex');
loop
fetch boys_cur into users;
exit when boys_cur%notfound;
dbms_output.put_line(users.user_name||'  '||users.password);
dbms_output.put_line(boys_cur%rowcount);
end loop;
close boys_cur;
end;
复制代码

循环游标

declare
cursor user_cur is select * from user_tbl;
begin
for username in user_cur loop
         dbms_output.put_line(username.user_name||'  '||username.sex);
end loop;
end;
复制代码

REF游标:

REF游标和游标变量用于处理运行时动态执行的SQL查询

创建游标变量的步骤:

a、 声明REF游标类型

b、 声明REF游标类型的变量

声明类型的语法

Type ref_cursor_name is ref cursor [return return_type];
复制代码

打开游标变量的语法

Open cursor_name for select_statement;
复制代码

声明强类型的游标

declare
type ref_cur is ref cursor return user_tbl%rowtype;
users_cur ref_cur;
复制代码

声明弱类型的游标

declare
type ref_cur is ref cursor;
users_cur ref_cur;
复制代码

三、子程序


子程序分为:存储过程和函数,它是命名的PL/SQL块,编译并存储在数据库中。

子程序的各个部分:声明部分,可执行部分,异常处理部分。

过程----执行某些操作

函数----执行操作并返回值

==========存储过程==========

创建过程的语法:

create or replace procedure
proce_name (parameter_list)
is|as
local variable declaration
begin
executable statements
exception
exception_handlers
end proce_name;
复制代码

过程参数的三种模式:

In----用于接收调用的值,默认的参数模式

Out----用于向调用程序返回值

In out----用于接收调用程序的值,并向调用程序返回更新的值

执行过程的语法:

Execute proce_name(parameter_list);
复制代码

Declare
Variable var_list;
Begin
Proce_name(var_list);
End;
复制代码

将过程执行的权限授予其他用户:

Grant execute on proce_name to scott;
Grant execute on proce_name to public;
复制代码

删除存储过程:

Drop procedure proce_name;
复制代码

==========函数==========

创建函数的语法:

Create or replace function
Fun_name (parameter_list)
Return datatype is|as
Local declarations
Begin
Executable statements;
Return result;
Exception
Exce_handlers;
End;
复制代码

函数只能接收in参数,不能接受out或in out参数,形参不能是PL/SQL类型

函数的返回类型也必须是数据库类型

访问函数的方式:

a、 使用PL/SQL块

b、使用SQL语句

Select fun_name(parameter_list) from dual;


作者:zhulin1028

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关文章
|
27天前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
151 64
|
14天前
|
SQL 存储 Oracle
[Oracle]知识点
本文主要介绍了Oracle数据库的相关知识点,包括数据类型、视图的使用及注意事项,并提供了详细的示例和扩展阅读链接。内容涵盖char族数据类型、number(a, b)数据类型、视图的创建与管理等,适合初学者和进阶用户参考学习。
39 4
[Oracle]知识点
|
17天前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
25 7
|
17天前
|
Oracle 关系型数据库 数据库
oracle数据库技巧
【10月更文挑战第25天】oracle数据库技巧
21 6
|
17天前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
17 5
|
24天前
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。
|
26天前
|
监控 Oracle 关系型数据库
Oracle数据库性能优化
【10月更文挑战第16天】Oracle数据库性能优化是
25 1
|
8天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
23 4
|
6天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
19 1
|
15天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
81 1

推荐镜像

更多