一、参数游标
参数游标是带有参数的游标,在定义参数游标之后,当使用不同参数值多次打开游标时,可以产生不同的结果集,语法如下:
cursor cursor_name(parameter_name datatype) is select_statement;
定义参数游标时,游标参数只能指定数据类型,而不能指定长度。
示例如下:
declare
cursor temp_cursor(no number) is select name from cip_temps where id=no;
v_name cip_temps.name%type;
begin
open temp_cursor(1);
loop
fetch temp_cursor into v_name;
exit when temp_cursor%notfound;
dbms_output.put_line(v_name);
end loop;
close temp_cursor;
end;
二、使用游标更新或删除数据
通过使用显示游标,不仅可以一行一行的处理select语句结果,而且也可以更新或删除当前游标的数据,注意,如果要通过游标更新或删除数据,在定义游标时一定要带有for update子句,语法如下:
cursor cursor_name(parameter_name datatype) is select_statement for updae [of column_reference][nowait];如上所示:for update子句用于在游标结果集数据上加行共享锁,以防止其他用户在相应行上执行DML操作,当select语句要引用到多张表是,使用of子句可以确定哪些表要加锁,如果没有of子句,则会在select语句所引用的全部表上加锁,nowait用于指定不等待锁,为了更新或删除当前游标行数据,必须在update 或delete语句中引用where current of 子句,语法如下:
update table_name set column=.. where current of cursor_name;
delete from table_name where current of cursor_name;
1、使用游标更新数据
declare
cursor temp_cursor is select name,address,id from cip_temps for update;
v_name cip_temps.name%type;
v_address cip_temps.ADDRESS%type;
v_id cip_temps.id%type;
begin
open temp_cursor;
loop
fetch temp_cursor into v_name,v_address,v_id;
exit when temp_cursor%NOTFOUND;
if(v_id>4) then
update cip_temps set name='name'||to_char(v_id),address='address'||to_char(v_id) where current of temp_cursor;
end if;
end loop;
close temp_cursor;
end;
2、使用游标删除数据
declare
cursor temp_cursor is select name,address,id from cip_temps for update;
v_name cip_temps.name%type;
v_address cip_temps.ADDRESS%type;
v_id cip_temps.id%type;
begin
open temp_cursor;
loop
fetch temp_cursor into v_name,v_address,v_id;
exit when temp_cursor%NOTFOUND;
if(v_id>2) then
delete from cip_temps where current of temp_cursor;
end if;
end loop;
close temp_cursor;
end;
3、使用of子句在特定表加行共享锁。
如果使用子查询涉及到多张表,那么默认情况下会在所有表上加行共享锁,为了只在特定表上加行共享锁,需要在for update子句后带有of子句,of后面跟字段名,如果跟表名或游标名称,则会报错:标示符无效。示例如下:
declare
cursor gData is select name,address,cip_temps.id from cip_temps,cip_t
where cip_temps.id=cip_t.id for update of address;
rs gData%rowtype;
begin
open gData;
loop
fetch gData into rs;
exit when gData%notfound;
if rs.id=1 then
delete from cip_temps where current of gData;
else
update cip_temps set name='塞北的雪' where current of gData;
end if;
end loop;
close gData;
end;
4、使用nowait子句
使用for update语句对被作用于行加锁,如果其他会话已经在被作用于行上加锁,那么默认情况下当前会话要一直等待对方释放锁,通过在for update子句中指定 nowait语句,可以避免等待锁,当指定了nowait子句之后,如果其他会话已经在被作用行加锁,那么当前会话会显示错误提示信息,并退出PL/SQL,示例如下:
declare
cursor gData is select name,address,cip_temps.id from cip_temps,cip_t
where cip_temps.id=cip_t.id for update nowait;
rs gData%rowtype;
begin
open gData;
loop
fetch gData into rs;
exit when gData%notfound;
if rs.id=1 then
delete from cip_temps where current of gData;
else
update cip_temps set name='塞北的雪' where current of gData;
end if;
end loop;
close gData;
end;
三、游标for循环
使用游标for循环是循环游标最简单的方法,oracle会隐含打开游标、循环提取数据、关闭游标,语法如下:
for record_name in cursor_name loop
..........
end loop;
如上所示:cursor_name是已经定义的游标名称,record_name是oracle隐含定义的记录变量。
1、使用游标for循环
当使用游标开发程序时,建议使用for循环,从而简化代码程序,示例如下:
declare
cursor temp_cursor is select name,age,address,id from cip_temps;
begin
for emp_record in temp_cursor loop
dbms_output.put_line(temp_cursor%rowcount||'第一行数据:'||emp_record.name||':'|| emp_record.age||':'|| emp_record.address||':'|| emp_record.id);
end loop;
end;
2、在游标for循环时直接使用子查询
declare
begin
for emp_record in (select * from cip_temps) loop
dbms_output.put_line('第一行数据:'||emp_record.name||':'|| emp_record.age||':'|| emp_record.address||':'|| emp_record.id);
end loop;
end;
分享到:
相关推荐
oracle视频教程(游标、子程序、包) oracle视频教程(游标、子程序、包)
总的来说,《Oracle_database_11g_SQL开发指南》是一本全面且实用的教程,无论你是刚接触Oracle的新手,还是希望通过学习深化数据库知识的专业人士,都能从中受益。配合提供的PDF文档,你可以随时随地学习和查阅,...
- **过程(PROCEDURE)**:无返回值的子程序,可以有参数输入和输出。 - **函数(FUNCTION)**:返回单个值的子程序,也可以有参数。 - **包(PACKAGE)**:将相关的过程和函数组织在一起,提供模块化和封装。 6...
9. **子程序和包**:存储过程和函数是可重用的代码单元,用于执行特定任务。包是包含相关过程、函数和变量的集合,提供模块化和封装。 10. **游标变量和记录类型**:游标变量用于存储游标的当前状态,而记录类型...
Oracle 游标是 PL/SQL 程序中的一种重要组件,用于处理查询结果集。游标可以分为隐式游标和显式游标两种,隐式游标由 PL/SQL 管理,隐式游标打开时查询开始,查询结束时隐式游标自动关闭。显式游标需要在 PL/SQL 块...
Oracle PL/SQL 讲义第 23 章 使用子程序和包 本章要点: * 掌握存储子程序与数据字典的交互方式及如何从 SQL 语句中调用存储子程序 * 了解存储子程序和局部子程序的区别 * 掌握存储子程序在 Oracle8i 和 Oracle9i ...
5. **子程序**:包括过程(PROCEDURE)和函数(FUNCTION),它们可以封装代码并多次调用,提高代码复用性。函数可返回一个值,而过程不返回。 6. **游标**:游标用于处理SQL查询结果集,允许逐行操作数据,常用于...
通过深入学习和实践上述知识点,你可以有效地使用Oracle PL/SQL进行数据库管理和应用开发。参考提供的"Oracle,PL-SQL.pdf"文档,结合"www.pudn.com.txt"中可能包含的资源,将有助于你更全面地理解Oracle PL/SQL的...
1. Oracle SQL基础:Oracle SQL遵循SQL标准,但增加了许多自己的扩展特性,如子查询、连接查询、集合操作、游标、触发器等。在学习Oracle SQL时,你需要理解如何创建表、视图、索引,以及如何插入、更新和删除数据。...
描述中提到“Oracle,PL/SQL操作手册,主要介绍语法等”,意味着这份资料可能详尽地涵盖了PLSQL的基本语法、数据类型、变量声明、控制结构(如IF-THEN-ELSE、CASE语句)、循环(WHILE、FOR循环)、子程序(过程和函数...
### ORACLE_PlSql-甲骨文学习笔记 #### 一、创建表 ##### 创建表一 ```sql CREATE TABLE TABLE_NAME ( AAA INTEGER CONSTRAINT PK_TABLE_NAME PRIMARY KEY, BBB VARCHAR2(10) NOT NULL, DOB DATE, CCC VARCHAR...
Oracle PL/SQL是一种强大的编程语言,它...学习PL/SQL对于开发Oracle数据库应用程序、维护数据库逻辑和优化性能至关重要。通过阅读Oracle2BPL-SQL.pdf,初学者可以逐步掌握这一强大工具,提升数据库管理和开发的能力。
### ORACLE_PLSQL学习总结(提高) #### 一、PL/SQL 块中的操作限制 在PL/SQL块中可以执行的操作主要包括:SELECT、DML(如INSERT、UPDATE、DELETE)以及事务控制语句(如COMMIT、ROLLBACK、SAVEPOINT)。然而,...
3. **子查询**:Oracle SQL中的子查询允许在查询中嵌套查询,用于比较、筛选或者组合复杂的数据。 4. **联接操作**:Oracle支持多种类型的联接,包括内连接(INNER JOIN)、外连接(LEFT JOIN, RIGHT JOIN, FULL JOIN)...
"OracleTest"作为子文件名,很可能是一个实现以上功能的测试脚本或应用程序。它可能包含了设置连接参数、执行SQL语句、异常处理、性能评估等逻辑。对这个程序的深入理解和调试,有助于确保与Oracle数据库的交互是...
`UPDATE_XML_OUTPUT_FORMAT`子程序修改了并发请求的参数,将输出格式设置为RTF。这可能是在准备XML输出时的预处理步骤,确保后续的XML生成符合预期的格式。 2. **数据准备**: 在`XML_PRINT`过程中,首先打开一个...
4. **子程序设计**:学习如何创建和调用过程、函数,以及参数传递。 5. **性能优化**:掌握如何编写高效的PL/SQL代码,避免全表扫描和减少资源消耗。 “Oracle PLSQL Programming.chm”这个文件很可能是对这些内容...
- **SQL语言**:Oracle支持标准SQL,包括数据查询、数据更新、数据插入和删除操作,以及更复杂的子查询、连接查询、聚合函数和窗口函数等。 - **数据库管理**:包括数据库的创建、启动、关闭、备份和恢复,以及表...
游标是Oracle数据库中的一种重要机制,它允许程序逐行处理查询结果集。游标本质上是一个可以从包含多条记录的结果集中每次提取一条记录的工具。当SQL SELECT语句返回的记录超过一条时,游标就显得非常有用。它能够将...
Oracle数据库是全球广泛使用的大型关系型数据库管理系统,其SQL(结构化查询语言)和PL/SQL(过程化语言/SQL)是操作、管理和开发Oracle数据库的核心工具。本指南旨在深入探讨这两个关键领域的知识,帮助你成为...