- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
oracle_ppt 第6章
第六章
数据库对象(二)
课程目标
游标,触发器,回退段
使用游标的各种程序
创建和使用触发器的各种程序
体验项目——游标里的判断及表的监控
本程序启动后,会自动判断游标是否有数据,如果有数据,就输出数据,且输出发现数据,如果没有数据,就输出没有数据,程序运行结果如图6-1所示。
图6-1 程序运行结果
监控是哪个用户在什么时间对你的表进行了操作,我们可以利用触发器很轻松地实现这个功能,程序运行结果如图6-2所示:
图6-2程序运行结果图
游标
游标的概念
游标是从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有一个数据指针,在初始状态下指向的是首记录,利用fetch语句可以移动该指针,从而对游标中的数据进行各种操作,然后将操作结果写回数据表中。
游标的定义
游标作为一种数据类型,首先必须进行定义,其语法如下:
cursor 游标名 is select 语句;
cursor是定义游标的关键词,select是建立游标的数据表查询命令。
游标的打开操作
如果要使用创建好的游标,需要先打开游标,语法结构如下:
open 游标名;
打开游标的过程有以下两个步骤:
(1)将符合条件的记录送入内存。
(2)将指针指向第一条记录。
游标提取数据的操作
如果要提取游标中的数据,需要使用fetch命令,语法形式如下。
fetch 游标名 into 变量名1, 变量名2,……;
或fetch 游标名 into 记录型变量名;
set serveroutput on
declare tempsal scott.emp.sal%type;
cursor mycursor is
select * from scott.emp
where saltempsal;
cursorrecord mycursor%rowtype;
begin tempsal:=800;
open mycursor;
fetch mycursor into cursorrecord;
dbms_output.put_line(cursorrecord.deptno);
end;
示例代码:
定义cursorrecord变量是游标mycursor的记录行变量
在游标mycursor的结果中找到sal字段大于800的第一个记录
显示deptno字段的内容
游标的关闭
使用完游标后,要关闭游标,使用close命令,语法形式如下:
close 游标名;
例如,如果要关闭上例中的游标,就需要在end前加上如下的语句:
close mycursor;
游标的属性
游标提供的一些属性可以帮助编写PL/SQL程序,游标属性的使用方法为:
游标名[属性]
例如mycursor%isopen,表示mycursor游标使用了属性%isopen
主要的游标属性如下: %isopen 、%found 、%rowcount 。
1.%isopen属性
该属性功能是测试游标是否打开,如果没有打开游标使用fetch语句将提示错误。示例代码如下:
set serveroutput on
declare tempsal scott.emp.sal%type;
cursor mycursor is
select * from scott.emp
where saltempsal;
cursorrecord mycursor%rowtype;
begin tempsal:=800;
if mycursor%isopen then
fetch mycursor into cursorrecord;
dbms_output.put_line(to_char(cursorrecord.deptno));
else dbms_output.put_line(游标没有打开!);
end if;
end;
该程序利用%isopen属性判断游标是否打开
2.%found属性
该属性功能是测试前一个fetch语句是否有值,有值将返回true,否则为false。示例代码如下:
set serveroutput on
declare tempsal scott.emp.sal%type;
cursor mycursor is
select * from scott.emp
where saltempsal;
cursorrecord mycursor%rowtype;
begin temp
您可能关注的文档
- Noise Induced Phenomena in Lotka-Volterra Systems.pdf
- Noise Level Estimation Fractal.pdf
- Noise sequences of infinite matrices and their applications to the characterization of the.pdf
- Noise removal in magnetic resonance diffusion tensor imaging.pdf
- Noise spectroscopy and interlayer phase-coherence in bilayer quantum Hall systems.pdf
- Noisesystem噪声基本算法简介第三版.pdf
- nomexT410说明书.pdf
- NoisewareProPluginHelp.pdf
- Non Linear Breaking of the Electroweak Symmetry and Large Extra Dimensions.pdf
- Non-distributive algebraic structures derived from nonextensive statistical mechanics.pdf
最近下载
- 路桥中学高一物理第一章单元测试题.doc VIP
- 脑出血病人麻醉管理.pptx VIP
- 江苏大学849经济学原理专业课考研真题(2019年).pdf VIP
- 数学活动 利用全等设计图案、证明拼图猜想(教案)2025-2026学年度人教版数学八年级上册.docx VIP
- 临床微生物基础操作规程.pdf VIP
- 2025年理解“情境+问题串”,探寻教学实践路径——以北师大版一年级上册为例.docx
- 网络安全知识宣传科普主题班会-网络安全伴我行.pptx VIP
- 专题15二次函数综合题旋转类(原卷版+解析).docx VIP
- 机械电子工程专业的生涯规划.pptx VIP
- 护士长专业知识培训总结.pptx VIP
原创力文档


文档评论(0)