Oracle数据库—— 游标的创建和应用
一、涉及内容
游标的创建与应用
二、具体操作
(一)填空题
1.PL/SQL 程序块主要包含3个部分:声明部分、(执行部分 )、异常处理部分。
2.自定义异常必须使用(RAISE )语句引发。
(二)选择题
1.下列哪一个不是BOOLEAN变量可能的取值?(D )
A.TRUE B.FALSE C.NULL D.BLANK
2.请查看以下IF语句:
Declare
sal number:=500;
comm number;
Begin
If sal <100 then
Comm :=0;
Elsif sal <600 then
Comm: =sal*0.1;
Else sal <1000 then
Comm: =sal*0.15;
Else
Comm: =sal*0.2;
End if;
End;
在执行了以上语句之后,变量comm 的结果应是:(B )
A.0 B.50 C.75 D.100
3.在以下哪些语句中可以包含WHERE CURRENT OF 子句?(CE)
A.OPEN B.FETCH C.DELETE D.SELECT E.UPDATE F.CURSOR
4.在异常和oracle错误之间建立关联时,应该在哪个部分完成?(A)
A.定义部分 B.执行部分 C.异常处理部分
5.只能存在一个值的变量是哪种变量?(B )
A.游标 B.标量变量 C.游标变量 D.记录变量
(三)编程题
1.编写程序计算并输出1~100的和。
方案一:
语句:
Declare
v_sum integer:=0;
begin
for i in 1..100 loop
v_sum := v_sum+i;
end loop;
dbms_output.put_line(‘1~100的和为:’|| v_sum);
end;
/
截图:

方案二:
语句:
Declare
v_sum integer;
begin
v_sum := 100*101/2;
dbms_output.put_line(‘1~100的和为:’|| v_sum);
end;
/
截图:

2.分别使用显式游标和隐式游标逐行输出scott.emp表中的员工姓名和工资。
(一)使用显式游标
语句:
DECLARE
CURSOR emp_cursor01 IS SELECT ename,sal FROM scott.emp;
emp_record emp_cursor01%ROWTYPE;
BEGIN
OPEN emp_cursor01 ;
LOOP
FETCH emp_cursor01 INTO emp_record;
EXIT WHEN emp_cursor01%NOTFOUND;
dbms_output.put_line('ename:'||emp_record.ename||',sal:'||emp_record.sal);
END LOOP;
dbms_output.put_line('row count:'||emp_cursor01%rowcount);
CLOSE emp_cursor01;
END;
截图:

(二)使用隐式游标
语句:
BEGIN
FOR emp_record IN (SELECT ename,sal FROM scott.emp)
LOOP
dbms_output.put_line('ename:'||emp_record.ename||',sal:'||emp_record.sal);
END LOOP;
END;
截图:

(补充练习)
1、 创建一个表top_dogs,包含两列:name varchar2(25) 和 salary NUMBER(11,2),用来存放员工姓名和工资。
语句:
create table top_dogs
(name varchar2(25),
salary NUMBER(11,2));
截图:

2、创建一个PL/SQL块,查询出工资水平前n名的员工。具体要求如下:
(1)通过替代变量读取n的值。
(2)通过循环从emp表中获取工资在前n名的员工的姓名和工资
(3)将得到的员工姓名和工资写入top_dogs表。
(4)如果有多名员工的工资相同,则每人都占n名中的一个名额。
(5)测试特殊情况,例如n=0或者n大于员工总数。
(6)每次向top_dogs 表中写入数据前,先清空该表中的数据。
方案一:
语句:
DECLARE
CURSOR emp_cursor(n number) IS SELECT ename,sal FROM scott.emp
ORDER BY sal DESC;
v_n integer := &n;
BEGIN
delete from top_dogs;
FOR rec IN emp_cursor(v_n) LOOP
IF emp_cursor%ROWCOUNT <=v_n THEN
insert into top_dogs values(rec.ename,rec.sal);
dbms_output.put_line('ename: '||rec.ename||' sal:'||rec.sal);
ELSIF v_n<=0 or v_n>emp_cursor%ROWCOUNT then
dbms_output.put_line('error!');
ELSE EXIT; --退出循环
END IF;
END LOOP;
END;
/
截图:

n=3以及n=4:

测试n=0以及n=100的情况:

方案二:
语句:
DECLARE
CURSOR emp_cursor IS SELECT ename,sal FROM scott.emp
ORDER BY sal DESC;
v_n integer := &n;
BEGIN
delete from top_dogs;
FOR rec IN emp_cursor
LOOP
Exit when emp_cursor%notfound;
Exit when emp_cursor%ROWCOUNT>v_n;
insert into top_dogs values(rec.ename,rec.sal);
-- dbms_output.put_line('ename: '||rec.ename||' sal:'||rec.sal);
END LOOP;
END;
/
截图:

输入n:2

输入n:3
Select * from top_dogs

输入n:0
Select * from top_dogs

输入n:100
Select * from top_dogs

3、在上题的基础上,如果员工工资相同(并列第几名),需要将前n名的员工全部输出。
语句:
DECLARE
CURSOR emp_cursor IS SELECT ename,sal FROM scott.emp
ORDER BY sal DESC;
v_n integer := &n;
v_sal scott.emp.sal%type;
BEGIN
delete from top_dogs;
FOR rec IN emp_cursor
LOOP
Exit when emp_cursor%notfound;
Exit when emp_cursor%ROWCOUNT>v_n and v_sal<>rec.sal;
V_sal:= rec.sal;
insert into top_dogs values(rec.ename,rec.sal);
-- dbms_output.put_line('ename: '||rec.ename||' sal:'||rec.sal);
END LOOP;
END;
输入n 的值:2
Select * from top_dogs
有三条记录
截图:

4、使用游标查询dept表的部门编号和名称,将其部门编号传递给另一个用于查询emp表的游标(查询emp表的员工姓名,工作,雇佣日期,工资)。
语句:
Declare
Cursor dept_cur is select deptno,dname from scott.dept;
Cursor emp_cur (c_deptno scott.emp.deptno%type) is select ename,job,hiredate,sal from scott.emp where deptno=c_deptno;
Emp_rec emp_cur%rowtype;
Begin
For dept_rec in dept_cur
Loop
Open emp_cur(dept_rec.deptno);
Loop
Fetch emp_cur into Emp_rec;
Exit when emp_cur%notfound;
Dbms_output.put_line('ename:'|| Emp_rec.ename||' job:'|| Emp_rec.job||' hiredate:'|| Emp_rec.hiredate||' sal:'|| Emp_rec.sal);
End loop;
Close emp_cur;
End loop;
End;
/
截图:

5、为emp表增加一个列stars,类型为VARCHAR2(100)。使用游标更新stars列:创建一个PL/SQL块,根据员工的工资计算他能获得的星号“*”数量,每100美元奖励一个星号,按四舍五入处理。并根据员工所获得的星号数量n,形成由n个星号组成的字符串,写入emp表的stars列。
(1)为emp表增加一个列stars,类型为VARCHAR2(100)。

(2)使用游标更新stars列:
语句:
Declare
v_stars scott.emp.stars%type;
v_num number:=0;
Cursor c1 is select empno,sal,stars from scott.emp;
Begin
For emp_rec in c1
Loop
v_stars:='';
exit when c1%notfound;
v_num:=round(emp_rec.sal/100);
for i in 1..v_num
loop
v_stars:= v_stars||'*';
end loop;
update scott.emp set stars= v_stars where empno=emp_rec.empno;
end loop;
end;
截图:


Oracle数据库—— 游标的创建和应用的更多相关文章
- 《Oracle Database 12c DBA指南》第二章 - 安装Oracle和创建数据库(2.1 安装Oracle数据库软件和创建数据库概览)
当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 2.1 安装Oracle数据库软件和 ...
- Spotlight监控Oracle数据库的链接创建
最近在做性能测试时,由于要挂载空间数据,开发人员直接将所有业务表都挂到了Oracle数据库中.最近做了几次测试发现响应时间和吞吐量都不是很理想,进行一番分析后怀疑可能在Oracle中出现问题,因此再网 ...
- Oracle数据库体系结构及创建表结构
Oracle服务器主要由实例.数据库.程序全局区和前台进程组成,其中实例就是用来提供管理数据库的功能:数据库由数据库文件组成,用来存储系统数据:实例可以进一步划分为系统全局区(SGA)和后台进程(PM ...
- Oracle数据库——触发器的创建与应用
一.涉及内容 1.理解触发器的概念.作用和类型. 2.练习触发器的创建和使用. 二.具体操作 (实验) 1.利用触发器对在scott.emp表上执行的DML操作进行安全性检查,只有scott用户登录数 ...
- 设置ORACLE数据库游标大小
先用超级管理员(sys)登陆服务器: sqlplus "sys/***@orcl as sysdba" 连接到:Oracle 查看ORACLE最大游标数: SQL> show ...
- Oracle数据库游标的类型
游标是SQL的一个内存工作区,由系统或用户以变量的形式定义.游标的作用就是用于临时存储从数据库中提取的数据块.Oracle数据库的Cursor类型包含三种: 静态游标:分为显式(explicit)游标 ...
- oracle 数据库中(创建、解锁、授权、删除)用户
上文我们已经建立了名为orcl66的数据库. 想要在数据库中创建.修改用户需要我们以管理员权限登录到数据库中. 首先我们通过sqlplus命令登录连接数据库. 输入sqlplus命令--用户名: sy ...
- 基于oracle数据库存储过程的创建及调用
1.PLSQL编程 1.1概念和目的 PL/SQL(Procedure Language/SQL) PLSQL是Oracle对sql语言的过程化扩展 指在SQL命令语言中增加了过程处理语句(如分支.循 ...
- Oracle数据库游标,序列,存储过程,存储函数,触发器
游标的概念: 游标是SQL的一个内存工作区,由系统或用户以变量的形式定义.游标的作用就是用于临时存储从数据库中提取的数据块.在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理, ...
随机推荐
- 基于HTML5+CSS3的图片旋转、无限滚动、文字跳动特效
本文分享几种基于HTML5+CSS3实现的一些动画特效:图片旋转.无限滚动.文字跳动;实现起来均比较容易,动手来试试! 一.图片旋转 效果图如下: 这个效果实现起来其实并不困难.代码清单如下: < ...
- 链表操作----将单链表向右旋转 K 个位置
给定一个单链表,设计一个算法实现链表向右旋转 K 个位置. 举例: 给定 1->2->3->4->5->6->NULL, K=3 则 4->5-> ...
- 调用未绑定的父类方法和使用supper 函数 之间的选择.
class New_int(int): # 定义一个新的类 继承 int 类 def __add__(self,other): # 重写 + 运算符 # __add__ 就是 int 中 + 的行为 ...
- BZOJ 3165 Segment
同上题. #include<iostream> #include<cstdio> #include<cstring> #include<algorithm&g ...
- 《深入浅出Node.js》第3章 异步I/O
@by Ruth92(转载请注明出处) 第3章 异步I/O Node 的基调:异步 I/O.事件驱动.单线程. Node 不再是一个服务器,而是一个可以基于它构建各种高速.可伸缩网络应用的平台. No ...
- MyBatis对应的xml的数据类型
MyBatis对应的xml的数据类型 JDBC Type Java TypeCHAR StringVARCHAR StringLONGVARCHAR StringNUMERIC java.math.B ...
- 一步一步理解word2Vec
一.概述 关于word2vec,首先需要弄清楚它并不是一个模型或者DL算法,而是描述从自然语言到词向量转换的技术.词向量化的方法有很多种,最简单的是one-hot编码,但是one-hot会有维度灾难的 ...
- EASYRECOVERY_3.3.29包含注册机、都教授数据恢复含注册码
用EASYRECOVERY恢复过U盘,和回收站永久清空的东西.效果很好.但疑惑doc,docx,后者恢复效果特别好 都教授没用过,别人买的,没用,很贵. 每次用,都找不着,还要重新淘宝买.这次分享给大 ...
- android定时更新文件
static变量在程序退出时不会清空的,除非系统内存不足以运行其他程序,才会清空.给SD卡上的文件过期时间.可以简单的在给文件命名时后面加个创建时间,在下次访问时判断是否需要更新.比如本来文件名是 i ...
- CoreOS 835.12.0 稳定版安装
导读 CoreOS是一个基于Docker的轻量级容器化Linux发行版,为Docker而生,CoreOS作为Docker生态圈中的重要一员,日益得到各大云服务商的重视,发展风头正劲. CoreOS宣称 ...