使用游标
1)显示游标:
CURSOR name_cursor IS select statement;
2)打开游标:
OPEN name_cursor;
3)提取游标
FETCH name_cursor INTO variable1,variable2.............
4)关闭游标
CLOSE name_cursor;
显示游标的属性:
%ISOPEN:显示游标是否打开
%FOUND:是否从结果集中取到数据
%NOTFOUND:是否未从结果集中取到数据
%ROWCOUNT:已经取到的数据,不是说集合中间有多少数据,请这里注意;
DECLARE
CURSOR a_cursor IS SELECT id,name from test1;
v_id test1.id%TYPE;
v_name test1.name%TYPE;
BEGIN
OPEN a_cursor;
FETCH a_cursor INTO v_id,v_name;
dbms_output.put_line(v_id);
dbms_output.put_line(v_name);
CLOSE a_cursor;
END;
使用游标更新或者删除数据:
如果想通过游标更新或者删除数据的话,那么在定义游标的时候必须指定 FOR UPDATE
如下:
CURSOR my_cursor IS SELECT * FROM test1 FOR UPDATE;
UPDATE table_name SET column=xx WHERE CURRENT OF name_cursor;
DELETE table_name WHERE CURRENT OF name_cursor;
必须指定WHERE CURRENT OF name_current;
使用例外:
EXCEPTION
WHEN e_name1 or e_name2 THEN
statement1;
WHEN 2_name3 THEN
statement2;
ELSE
statement3;
WHEN OTHERS THEN
statement4;
其中自定义异常是这样的:
DECLARE
e_name EXCEPTION;
BEGIN
RAISE e_name;
EXCEPTION
WHEN e_name THEN
dbms_output.put_line('异常抛出');
END;
使用复合数据:
TYPE my_record_type IS RECORD
DECLARE
TYPE my_record_type IS RECORD(
id test1.id%TYPE,
name test1.name%TYPE
);
r1 my_record_type;
BEGIN
SELECT id,name INTO r1 FROM test1 WHERE id=1;
dbms_output.put_line(r1.id || r1.name);
END;
DECLARE
TYPE my_record_type IS RECORD(
id test1.id%TYPE,
name test1.name%TYPE
);
r1 test1%ROWTYPE;
BEGIN
SELECT * INTO r1 FROM test1 WHERE id=1;
dbms_output.put_line(r1.id || r1.name);
END;
/
使用PL/SQl表:
DECLARE
TYPE my_table_type IS TABLE OF NUMBER(2,0)
INDEX BY BINARY_INTEGER;
name_table my_table_type;
BEGIN
select id BULK COLLECT INTO name_table from test1;
dbms_output.put_line(name_table(1));
End;
使用PL/SQL记录表:
DECLARE
TYPE my_table_type IS TABLE OF test1%ROWTYPE
INDEX BY BINARY_INTEGER;
name_table my_table_type;
BEGIN
select * BULK COLLECT INTO name_table from test1;
dbms_output.put_line(name_table(1).name);
End;
DECLARE
TYPE my_table_type IS TABLE OF test1%ROWTYPE
INDEX BY BINARY_INTEGER;
name_table my_table_type;
BEGIN
select * BULK COLLECT INTO name_table from test1; --count可以得到这个表的长度
FOR i in 1..name_table.count LOOP
dbms_output.put_line(name_table(i).name);
END LOOP;
End;
分享到:
相关推荐
ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括触发器、过程、函数、软件包、异常处理、游标、循环、分支、变量使用、数据库安装等关键知识点。 触发器是数据库中用来保证数据...
- **集合与记录**:学习如何使用PL/SQL中的集合和记录类型,这些结构可以帮助更高效地处理数据集。 - **游标**:介绍游标的使用方法,包括隐式游标和显式游标,以及如何利用游标遍历查询结果。 #### 四、PL/SQL中的...
总的来说,"Oracle PL/SQL 实例精解(第4版)"是一本全面的教程,不仅介绍了PL/SQL的基础,还涵盖了高级主题和实践案例,对于希望提升Oracle数据库编程技能的开发者来说,是一本不可多得的参考书籍。配合源码脚本,...
《精通PL/SQL》这本书是针对Oracle数据库系统中PL/SQL编程语言的深度解析与实践指南,主要面向希望提升在Oracle环境下使用PL/SQL技能的专业人士。PL/SQL,全称为Procedural Language/Structured Query Language,是...
2. **掌握数据操作**:熟悉如何使用PL/SQL对表进行增删改查操作。 3. **深入异常处理**:学习如何处理运行时错误,编写健壮的代码。 4. **实践案例**:教程可能包含实际的示例代码,帮助你将理论知识应用于实践中...
最后,书中可能还会涵盖PL/SQL在实际项目中的应用案例,比如如何使用PL/SQL构建复杂的业务逻辑,如何与其他编程语言(如Java、C#)集成,以及如何使用PL/SQL处理数据库的并发问题。 总之,《PL/SQL程序设计》这本书...
- 游标是PL/SQL中的一个强大特性,用于处理记录集。 - 可以定义显式游标来检索查询结果,并通过循环逐行处理每条记录。 4. **包**: - 包是PL/SQL的重要组成部分,用于组织和封装相关的子程序、游标、变量等。 ...
最后,书中会涵盖PL/SQL在实际项目中的应用案例,提供实际操作的指导,帮助读者将理论知识转化为实际技能。此外,书中可能还包含了一些实用的工具和技巧,如调试PL/SQL代码、错误处理和日志记录等,以提升开发效率和...
- 性能分析:使用动态性能视图(如V$SESSION,V$SQL,V$SQLAREA等)监控SQL和PL/SQL执行情况。 - 优化器统计信息:定期收集和更新,确保优化器做出正确的执行计划选择。 - AWR和ASH报告:Oracle自动工作区管理和...
PL/SQL使用的字符集包括所有大写和小写字母、0-9的阿拉伯数字以及各种操作符。这些字符构成了PL/SQL程序的基础。 #### 四、PL/SQL标识符 - **最大长度**:30个字符 - **不区分大小写**:尽管PL/SQL不区分大小写,...
- PL/SQL包和类型:创建和使用 - PL/SQL中的对象关系编程 10. **AppendixA - 实战案例与解决方案** - 解决实际问题的PL/SQL代码示例 - 复杂业务逻辑的实现 - 应对挑战性的性能问题 这些章节覆盖了从基础到...
3. **游标**:游标是PL/SQL中处理单行结果集的关键工具,用于动态地处理SQL查询结果。书中会详细解释游标的使用方法,包括隐式游标和显式游标,以及如何在循环中使用游标。 4. **记录和集合**:PL/SQL支持用户定义...
总结来说,"PL/SQL应用开发实训指导"旨在帮助开发者熟练运用PL/SQL进行Oracle数据库的程序设计,通过实际操作和案例分析,提升开发技能。在学习过程中,除了掌握基本语法和编程结构,还要理解数据库原理,以便更好地...
该示例展示了如何使用PL/SQL来处理复杂的业务逻辑。 ```plsql DECLARE -- 定义变量 v_bonus NUMBER; BEGIN -- 计算奖金 SELECT salary * 0.15 INTO v_bonus FROM employees WHERE employee_id = 100; -- 插入...
《PL/SQL语言优化以及编程培训教材》是一份详尽且深入的学习资源,旨在帮助用户提升在Oracle数据库环境中使用PL/SQL的技能和效率。PL/SQL,全称Procedural Language/Structured Query Language,是Oracle数据库系统...
包是一种组织PL/SQL对象(如子程序、游标、变量等)的方式。通过将相关的对象组合在一起,可以提高代码的可读性和可维护性。 ##### 5.3 类型定义 PL/SQL允许用户定义自己的数据类型,包括记录类型、集合类型等。...
- 游标函数:返回一个游标类型的函数,可以作为其他PL/SQL块的输入,使得游标可以在多个层次的调用结构中使用。 10. **游标与事务管理** - 游标操作可以包含在事务中,确保数据的一致性和完整性。 - 提交或回滚...