网站首页 > 技术文章 正文
1.PL/SQL中过程、函数以及包的概念
过程、函数与包都属于PL/SQL语句块中的命名块,过程和函数统称为子程序。包是一个逻辑单位,PL/SQL可以让开发人员把逻辑相关的类型、变量、游标和子程序放在一个包里,这样更加清楚,易理解。包通常由如下两部分组成:
包规范部分:定义程序接口,声明类型、常量、变量、异常、游标和可以使用的子程序声明。(有点类似于C语言中的头文件)
包体:用于实现包规范部分声明的子程序和游标。
2.游标的使用
游标是一个指向上下文区域的指针,这个上下文区域是PL/SQL语句块中在执行SELECT语句或者DML数据操纵语句时分配的。
游标的分类: 显式游标和隐式游标
(1) 显示游标的使用:
1)声明游标
CURSOR mycur(vartype number) is
select emp_no,emp_zc from cus_emp_basic
where com_no = vartype;
2)打开游标:
open mycur(000627) 注:000627:参数
3)读取数据
4)关闭游标
close mycur;
(2)游标的属性
Oracle 游标有4个属性: %ISOPEN , %FOUND , %NOTFOUND, %ROWCOUNT
%ISOPEN 判断游标是否被打开,如果打开%ISOPEN 等于true,否则等于false
%FOUND %NOTFOUND 判断游标所在的行是否有效,如果有效,则%FOUNDD等于true,否则等于false
%ROWCOUNT 返回当前位置为止游标读取的记录行数。
(3)基于游标定义记录变量
使用%ROWTYPE属性不仅可以基于表和视图定义记录变量,也可以基于游标定义记录变量。当基于游标定义记录变量时,记录成员名实际就是SELECT语句的列名和列别名。
(4)隐式游标的使用:
如果在pl/sql程序中使用了select语句进行操作,pl/sql会隐含处理游标定义,即称做隐式游标。这种游标不需要声明、打开和关闭。
使用隐式游标时要注意以下几点:
A、每一个隐式游标必须有一个into;
B、和显示游标一样,带有关键字into接收数据的变量时数据类型要与列表一致。
C、隐式游标一次只能返回移行数据。
(5)典型游标for 循环
游标for循环和显示游标的一种快捷使用方式,它使用for循环依次读取结果集中的行数据,当for循环开始时,游标自动打开(不需要open),每循环一次系统自动读取游标当前行的数据(不需要fetch),当退出for循环时,游标被自动关闭(不需要使用close)使用游标for循环的时候不能使用open语句,fetch语句和close语句,否则会产生错误。
(6)在游标FOR循环中使用查询
在游标FOR循环中可以定义查询,由于没有显式声明所以游标没有名字,记录名通过游标查询来定义。
3.delete与truncate 区别
1)truncate 是DDL语句,delete 是DML语句;
2)truncate 速度远快于 delete.原因是:当我们执行delete操作时所有表数据先被copy到回滚表空间,数据量不同花费时间长短不一。而truncate是直接删除数据不进回滚表空间。
3)接(2)这也就导致了delete数据后我们可以运行rollback进行数据回滚,而truncate则是永久删除不能回滚;
4)truncate 操作不会触发表上的delete触发器,而delete会正常触发;
5)truncate语句不能带where条件意味着只能全部数据删除,而delete可删除部分数据;
6)truncate 操作会重置表的高水位线(High Water Mark),而delete不会。
4.Oracle集合操作
1)UNION: 由每个查询 选择的 所有不重复的行组成。并集不包含重复值, 默认按第 1 个查询的第 1 列升序排列。
2)UNION ALL:由每个查询 选择的 所有的行,完全并集包含重复值, 不排序。
3)MINUS : 在第一个查询中,不在后面查询中的行。不包含重复, 按第1 个查询的第 1 列升序排列。
4)INTERSECT:取每个查询结果的交集, 不包含重复行, 按第1 个查询的第 1 列升序排列。
5.Oracle常用函数
NVL与NVL2操作
1) NVL (expr1, expr2):expr1为NULL,返回expr2;不为NULL,返回expr1。注意两者的类型要一致
2) NVL2 (expr1, expr2, expr3) :expr1不为NULL,返回expr2;为NULL,返回expr3。expr2和expr3类型不同的话,expr3会转换为expr2的类型
DECODE
SUBSTR
SUBSTR(v_tran_stat, p_card_arch.card_state, 1);
INSTR
6.Oracle触发器
触发器是只在事件发生时隐式地自动执行的PL/SQL块,不能接受参数,不能被显式调用。
触发器包括DML触发器、替代触发器与系统事件触发器。
DML触发器是对数据表进行DML语句操作(如insert、update、delete)时所触发的触发器。
替代触发器是对视图进行操作时定义的触发器,该类型的触发器只能定义在视图上。
系统事件触发器是对数据库实例或某个用户模式进行操作时定义的触发器。
猜你喜欢
- 2025-06-10 隔离级别的追溯与究明,带你读懂隔离级别(下)
- 2025-06-10 数据管理与应用试题库(数据管理考试题库)
- 2025-06-10 oracle表分区的概念及操作(oracle分表分区优缺点)
- 2025-06-10 百万级数据库优化方案--Oracle 性能优化总结
- 2025-06-10 如何“破解”Oracle数据库性能测试过程中索引使用问题?
- 2025-06-10 【Oracle】Berkeley DB避“坑”(berkeley是什么大学)
- 2025-06-10 Seata源码—6.Seata AT模式的数据源代理一
- 2025-06-10 深入剖析Oracle SCN机制(oracle scheduler component)
- 2025-06-10 细说Oracle数据库与操作系统存储管理二三事
- 2025-06-10 oracle_silent (静默安装oracle)(oracle12c 静默安装)
- 1508℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 520℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 490℃MySQL service启动脚本浅析(r12笔记第59天)
- 469℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 467℃启用MySQL查询缓存(mysql8.0查询缓存)
- 447℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 427℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 424℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)