Oracle游标使用方法及语法大全
- 格式:docx
- 大小:47.30 KB
- 文档页数:28
oracle中游标的用法游标是Oracle数据库中一种重要的数据类型,用于处理查询结果集中的数据。
使用游标可以方便地遍历查询结果,进行数据处理和操作。
下面是关于Oracle中游标的用法的参考内容。
一、游标的定义与声明在Oracle数据库中,游标可以在PL/SQL块中使用,用于与查询结果进行交互。
游标的使用分为显示游标和隐式游标两种方式:1. 显示游标:显示游标需要先定义游标类型,然后声明游标变量,并使用OPEN、FETCH和CLOSE等操作进行操作。
示例代码如下:```sql-- 定义游标类型TYPE cursor_type IS REF CURSOR;-- 声明游标变量cursor_var cursor_type;-- 打开游标OPEN cursor_var FOR SELECT * FROM table_name;-- 循环获取游标数据LOOPFETCH cursor_var INTO variable1, variable2...;EXIT WHEN cursor_var%NOTFOUND;-- 对游标数据进行处理END LOOP;-- 关闭游标CLOSE cursor_var;```2. 隐式游标:隐式游标由Oracle自动管理,不需要程序员定义和声明,系统会自动为每一个SELECT语句分配一个隐式游标。
隐式游标无法手动控制游标操作,只能通过向结果集添加条件来限制查询结果。
示例代码如下:```sql-- 查询结果会被自动赋值给隐式游标SELECT * FROM table_name;-- 循环处理查询结果LOOP-- 对查询结果进行处理-- 退出循环条件END LOOP;```二、游标的属性和操作1. 游标属性:(1) %FOUND:如果游标指向的结果集中有数据,则返回真;否则返回假。
(2) %NOTFOUND:如果游标指向的结果集中没有数据,则返回真;否则返回假。
(3) %ROWCOUNT:返回游标当前处理的行数。
oracle 游标循环用法游标循环是在Oracle数据库中常用的一种技术,它允许我们按行循环访问查询结果集,并对每一行的数据进行操作。
在本文中,我将逐步解释Oracle游标循环的用法,并提供一些示例来帮助读者更好地理解。
第一步:游标的定义在使用游标之前,我们需要先定义一个游标。
游标是一个指向结果集的指针,用于从结果集中逐行获取数据。
在Oracle中,我们可以使用DECLARE 语句定义游标。
例如:DECLARECURSOR cursor_name ISSELECT column1, column2, ...FROM table_nameWHERE condition;在上面的示例中,我们定义了一个名为cursor_name的游标,它选择具有满足条件的结果集。
游标名可以根据需要进行自定义。
第二步:游标的打开和关闭在使用游标之前,我们需要先打开它,以便开始遍历结果集。
这可以通过使用OPEN语句来实现。
例如:OPEN cursor_name;在执行OPEN语句之后,游标将指向结果集的第一行。
在完成游标的使用后,我们应该关闭它。
这可以通过使用CLOSE语句来实现。
例如:CLOSE cursor_name;关闭游标后,游标将不再指向结果集的任何行。
第三步:游标的循环遍历一旦游标打开,我们可以使用游标的名称在循环中获取结果集的每一行。
在Oracle中,我们有两种循环方法可以使用游标:FOR循环和WHILE 循环。
1. FOR循环:FOR循环是使用游标的一种常用方法。
它允许我们在循环中自动遍历游标的所有行。
以下是FOR循环的语法:FOR record_name IN cursor_nameLOOP在这里可以对每一行的数据进行操作END LOOP;在上面的示例代码中,record_name是一个记录变量,表示结果集的一行数据。
在循环中,我们可以使用record_name来访问每一行的列值,并进行相应的操作。
2. WHILE循环:WHILE循环是另一种使用游标的循环方法。
Oracle游标声明这篇Oracle教程解释了如何在Oracle / PLSQL中声明游标的语法和⽰例。
游标是在PLSQL代码的声明部分中定义的SELECT语句。
下⾯来看看三种不同的语法来声明游标。
1. 没有参数的游标(最简单)在没有任何参数的情况下声明游标是最简单的游标。
语法Oracle / PLSQL中没有参数的游标的语法是:CURSOR cursor_nameISSELECT_statement;⽰例例如,可以像下⾯那样定义⼀个名为c1的游标。
CURSOR c1ISSELECT course_numberFROM courses_tblWHERE course_name = name_in;该游标的结果集是所有course_name,其course_name与name_in变量匹配。
下⾯是使⽤这个游标的函数。
CREATE OR REPLACE Function FindCourse( name_in IN varchar2 )RETURN numberIScnumber number;CURSOR c1ISSELECT course_numberFROM courses_tblWHERE course_name = name_in;BEGINOPEN c1;FETCH c1 INTO cnumber;if c1%notfound thencnumber := 9999;end if;CLOSE c1;RETURN cnumber;END;带参数游标随着来看更加复杂⼀点的应⽤,可以⽤参数声明游标。
语法Oracle / PLSQL中具有参数的游标的语法是:CURSOR cursor_name (parameter_list)ISSELECT_statement;⽰例例如,可以定义⼀个名为c2的游标,如下所⽰。
CURSOR c2 (subject_id_in IN varchar2)ISSELECT course_numberFROM courses_tblWHERE subject_id = subject_id_in;该游标的结果集是所有course_numbers,其subject_id与通过参数传递给游标的subject_id相匹配。
Oracle函数返回游标的方法及应用在Oracle中,游标是一种使用SELECT语句检索数据的数据库对象。
Oracle提供了一些内置函数来返回游标,这些函数可以用于各种应用和场景。
下面将介绍几个常用的Oracle函数返回游标的方法及其应用。
1.SYS_REFCURSORSYS_REFCURSOR是Oracle提供的一种特殊类型,可以用于返回游标。
它允许在PL/SQL程序中打开和操作游标,然后将其作为参数传递给其他过程或函数。
SYS_REFCURSOR的使用如下:```CREATE OR REPLACE FUNCTION get_employee_cursorRETURNSYS_REFCURSORISemp_cursor SYS_REFCURSOR;BEGINOPEN emp_cursor FOR SELECT * FROM employees;RETURN emp_cursor;END;```在上述例子中,`get_employee_cursor`函数返回一个SYS_REFCURSOR类型的游标,该游标打开并检索了employees表中的所有数据。
其他过程或函数可以调用这个函数来获取该游标,并使用FETCH语句获取数据。
2.CURSOR返回值在PL/SQL中,可以使用`CURSOR`来定义一个游标类型的变量,并将其作为函数的返回值。
这种方式主要用于在PL/SQL代码中处理游标。
下面是一个示例:```CREATE OR REPLACE FUNCTION get_employee_cursorRETURN employees%ROWTYPEISemp_cursor employees%ROWTYPE;BEGINSELECT * INTO emp_cursor FROM employees;RETURN emp_cursor;END;```在这个例子中,`get_employee_cursor`函数返回一个employees表中的行数据,使用`%ROWTYPE`声明了一个与employees表结构相匹配的记录类型变量emp_cursor。
Oracle数据库的游标和for循环使⽤1. 游标的概念和作⽤游标是 sql 的⼀个内存⼯作区,由系统或⽤户以变量的形式定义游标的作⽤就是⽤于临时存储从数据库中提取的数据块(结果集)。
它有⼀个指针,从上往下移动(fetch),从⽽能够遍历每条记录。
⽤牺牲内存来提升 SQL 执⾏效率,适⽤于⼤数据处理。
(摘抄⾃https:///qq_34745941/java/article/details/81294166)。
2.游标结构图3.具体⽤法 游标有四⼤属性,分别是1. “SQL%ISOPEN” :布尔类型。
判断游标是否打开 2.“SQL%FOUND”:布尔类型。
判断上⼀条fetch语句是否有值,有则为true,否则为false; 3.“SQL%NOTFOUND”:布尔类型。
与2相反,常⽤作退出循环的条件。
4.“SQL%ROWCOUNT”:整型。
当前成功执⾏更改的数据⾏数。
3.1 静态游标 3.1.1 隐式游标 使⽤DML操作(增删改)或select……into……会⾃动创建隐式游标,名称是“sql”,该游标会⾃动声明,打开和关闭。
⽆需⼈为开启或关闭。
create or replace procedure ATest(O_Result Out VarChar2)isv_id staff.id%type;begininsert into staff(id,name) values(1,'张三');if sql%found thenO_Result:='添加成功';end if;update staff set name ='李四'where id =1;if sql%found thenO_Result:='更新成功';end if;delete from staff where id =1;if sql%found thenO_Result:='删除成功';end if;select id into v_id from staff;if sql%found thenO_Result:='查询成功';end if;if sql%isopen thenO_Result:='游标为开启状态,但不可能⾛到这⼀步'; --游标只有在执⾏上述增删改操作才会开启并⾃动关闭elseO_Result:='游标为关闭状态';end if;exceptionwhen Others thenbeginO_Result:='N_SQLCODE is '||SQLCODE||' and SQLERRM is '||SQLERRM;rollback;end;end; 3.1.2 显式游标 显⽰游标⼜分为不带参数和带参数两种 ⽆参:create or replace procedure ATest(O_Result Out VarChar2)isv_cur_info staff%rowtype;cursor v_cur is--声明游标为staff表的数据集select*from staff;beginopen v_cur; --打开游标fetch v_cur into v_cur_info; --赋值给游标O_Result:='ID:'||v_cur_info.id||',Name:'||v_cur_;--输出值close v_cur; --关闭游标exceptionwhen Others thenbeginO_Result:='N_SQLCODE is '||SQLCODE||' and SQLERRM is '||SQLERRM;rollback;end;end;输出结果: ID:1,Name:张三带参:create or replace procedure ATest(O_Result Out VarChar2)isv_cur_info staff%rowtype;cursor v_cur(v_id staff.id%type) is--声明游标为staff表的数据集select*from staff where id =v_id; --参数:v_idbeginopen v_cur(1); --打开游标fetch v_cur into v_cur_info; --赋值给游标O_Result:='ID:'||v_cur_info.id||',Name:'||v_cur_;close v_cur; --关闭游标exceptionwhen Others thenbeginO_Result:='N_SQLCODE is '||SQLCODE||' and SQLERRM is '||SQLERRM;rollback;end;end;输出结果: ID:1,Name:张三 3.2 动态游标 3.2.1 ⾃定义类型游标 ⾃定义游标类型声明写法:TYPE ref_type_name IS REF CURSOR[RETURN return_type];ref_type_name代表我们⾃定义类型的名称,cursor是系统默认的return_type代表数据库表中的⼀⾏,或⼀个记录类型,是⼀个返回类型;返回值不是必要的,⽆返回值则称为弱类型,更加灵活;有返回值称为强类型,减少错误;弱类型写法:create or replace procedure ATest(O_Result Out VarChar2)isv_cur_info staff%rowtype;type v_cur_type is ref cursor; --⾃定义游标类型v_cur v_cur_type;beginopen v_cur for--打开游标并声明select*from staff where id<5;loop --开始循环fetch v_cur into v_cur_info; -- 赋值exit when v_cur%notfound; --判断没有值就退出循环O_Result:= O_Result||chr(10)||'ID:'||v_cur_info.id||',Name:'||v_cur_;end loop;close v_cur;exceptionwhen Others thenbeginO_Result:='N_SQLCODE is '||SQLCODE||' and SQLERRM is '||SQLERRM;rollback;end;end;另⼀种写法:create or replace procedure ATest(O_Result Out VarChar2)isv_sql varchar(1000);v_param staff.id%type:=5;v_cur_info staff%rowtype;type v_cur_type is ref cursor; --⾃定义游标类型v_cur v_cur_type;beginv_sql:='select * from staff where id <:id';open v_cur for v_sql --打开游标并声明using v_param; --绑定参数⽅法loop --开始循环fetch v_cur into v_cur_info; -- 赋值exit when v_cur%notfound; --判断没有值就退出循环O_Result:= O_Result||chr(10)||'ID:'||v_cur_info.id||',Name:'||v_cur_;end loop;close v_cur;exceptionwhen Others thenbeginO_Result:='N_SQLCODE is '||SQLCODE||' and SQLERRM is '||SQLERRM;rollback;end;end;强类型写法:三个注意事项:1.强类型⽆法使⽤绑定参数⽅法 2.for后⾯必须是sql,不能是字符串,如上⾯的v_sql; 3.参数必须对应;create or replace procedure ATest(O_Result Out VarChar2)isv_cur_info staff%rowtype;type v_cur_type is ref cursor return staff%rowtype ; --⾃定义游标类型v_cur v_cur_type;beginopen v_cur for--打开游标并声明select*from staff where id <5;loop --开始循环fetch v_cur into v_cur_info; -- 赋值exit when v_cur%notfound; --判断没有值就退出循环O_Result:= O_Result||chr(10)||'ID:'||v_cur_info.id||',Name:'||v_cur_;end loop;close v_cur;exceptionwhen Others thenbeginO_Result:='N_SQLCODE is '||SQLCODE||' and SQLERRM is '||SQLERRM;rollback;end;end; 3.2.2 系统类型游标 简写⼿动声明⾃定义游标的过程type v_cur_type is ref cursor return staff%rowtype ; --⾃定义游标类型v_cur v_cur_type;等同于 v_cur sys_refcursor;4.效率问题没有实际测试过,根据其他博客总结是这样:⼀般来说批量处理的速度要最好,隐式游标的次之,单条处理的最差以下是⽰例:1、批量处理open游标;loopfetch游标bulk collect into集合变量(也就是table类型哦) limit 数值; -- ⼀般 500 左右exit when条件--(变量.count = 0,如果⽤ sql%notfound 不⾜ limit 的记录就不会被执⾏哦)close游标;2、隐式游标for x in (sql 语句) loop... 逻辑处理end loop;3、单条处理open游标;loopfetch游标into变量;exit when条件end loop;close游标;————————————————原⽂链接:https:///qq_34745941/java/article/details/81294166批量处理的关键字不是很了解,下次学习下在记录起来;隐式游标写法最简洁明了,类似于程序中的for循环写法;单条处理⼤概就是上⾯那些范例的写法。
oracle cursor正确用法Oracle Cursor正确用法什么是Oracle Cursor在Oracle数据库中,Cursor(游标)是一种用于检索和操作结果集的数据库对象。
它可以被视为内存中的一个指针,用于指向查询结果集的当前行。
通过游标,我们可以对查询结果进行遍历和操作。
Cursor的声明和打开(OPEN)使用Cursor之前,需要先声明并打开它。
采用以下步骤:1.声明Cursor:CURSOR cursor_name IS query;–cursor_name是游标的名称,可以根据实际情况自行命名。
–query是查询的语句,可以是简单的SELECT语句,也可以包括一些复杂的逻辑。
2.打开Cursor:OPEN cursor_name;–cursor_name是要打开的游标名称。
Cursor的使用遍历结果集可以使用LOOP语句来遍历Cursor的结果集。
LOOPFETCH cursor_name INTO variable1, variable2, ...;EXIT WHEN cursor_name%NOTFOUND;-- 进行一些逻辑操作END LOOP;•FETCH语句用于获取当前行的数据,将其赋值给变量。
•EXIT WHEN cursor_name%NOTFOUND用于在结果集遍历完后跳出循环。
关闭Cursor在使用Cursor之后需要关闭它,释放资源。
CLOSE cursor_name;Cursor的参数传递Cursor还可以作为过程的参数进行传递。
通过传递Cursor,可以在不同的过程中复用相同的查询逻辑。
PROCEDURE procedure_name(cursor_name IN OUT SYS_REF CURSOR) IS...总结通过声明、打开、遍历和关闭Cursor,我们可以有效地操作Oracle数据库中的结果集。
同时,Cursor还可以作为过程的参数进行传递,在不同的过程中复用相同的查询逻辑。
Oracle显⽰游标的使⽤及游标for循环下⾯给⼤家介绍在什么情况下⽤隐式游标,什么情况下⽤显⽰游标:1.查询返回单⾏记录时→隐式游标;2.查询返回多⾏记录并逐⾏进⾏处理时→显式游标--显⽰游标属性declareCURSOR cur_emp IS SELECT * FROM emp;row_emp cur_emp%ROWTYPE;BEGINOPEN cur_emp;FETCH cur_emp INTO row_emp;WHILE cur_emp%FOUNDLOOPdbms_output.put_line(row_emp.empno||'----'||row_emp.ename);FETCH cur_emp INTO row_emp;END LOOP;close cur_emp;END;--使⽤显式游标修改数据(给所有的部门经理加薪1000)DECLARECURSOR emp_cur ISSELECT empno,ename,sal FROM emp WHERE job='MANAGER' FOR UPDATE;emp_row emp_cur%ROWTYPE;BEGINOPEN emp_cur;LOOPFETCH emp_cur INTO emp_row;IF emp_cur%NOTFOUND THENEXIT;ELSEUPDATE emp SET sal=sal+1000 WHERE CURRENT OF emp_cur;END IF;END LOOP;COMMIT;CLOSE emp_cur;END;·注意:1、如果游标打开之前或关闭之后,使⽤游标属性,Oracle会抛出⼀个INVALID_CURSOR错误(ORA-01001);2、如果在第⼀次fetch后结果集是空的,%found=false,%NotFound=true,%ROWCOUNT=0;3、如果使⽤了BULK COLLECT,那么%ROWCOUNT的值可能不是0或1,实际上他返回的是提取到相关集合的⾏数。
oracle 游标参数摘要:1.Oracle 游标的概念和作用2.Oracle 游标的种类3.Oracle 游标的使用方式4.Oracle 游标的参数5.Oracle 游标参数的应用实例正文:1.Oracle 游标的概念和作用Oracle 游标是Oracle 数据库中一种用于遍历和处理查询结果的机制。
游标允许用户在记录行间移动,同时对记录执行插入、更新和删除操作。
游标在存储过程、触发器和函数中使用得较多,它们提供了一种灵活的方式来处理查询结果集。
2.Oracle 游标的种类Oracle 游标主要有三种类型:(1)ROW_NUMBER:为每一行记录分配一个唯一的数字,方便遍历和处理记录。
(2)ROWID:表示记录在结果集中的物理位置,通常用于快速定位记录。
(3)KEY_SET:用于遍历结果集中的每一行,但不提供记录的物理位置信息。
3.Oracle 游标的使用方式要使用Oracle 游标,需要先创建一个游标,然后使用OPEN 语句打开游标。
接下来,可以使用FETCH 语句获取游标中的数据,使用CLOSE 语句关闭游标。
以下是一个简单的游标使用示例:```CREATE CURSOR my_cursor ISSELECT * FROM my_table;OPEN my_cursor;FETCH FROM my_cursor INTO variables;CLOSE my_cursor;```4.Oracle 游标的参数Oracle 游标参数是在创建游标时定义的,用于控制游标的行为。
以下是一些常用的游标参数:(1)游标名称:用于唯一标识游标。
(2)查询语句:用于定义游标的结果集。
(3)游标类型:用于指定游标的类型,如ROW_NUMBER、ROWID 或KEY_SET。
(4)游标选项:用于控制游标的一些特定行为,如自动提交、滚动游标等。
5.Oracle 游标参数的应用实例假设有一个名为“employees”的表,包含以下列:id、name、salary。
关键词:显式游标当查询返回结果超过一行时,就需要一个显式游标,此时用户不能使用select into语句。
PL/SQL管理隐式游标,当查询开始时隐式游标打开,查询结束时隐式游标自动关闭。
显式游标在PL/SQL块的声明部分声明,在执行部分或异常处理部分打开,取出数据,关闭。
使用游标这里要做一个声明,我们所说的游标通常是指显式游标,因此从现在起没有特别指明的情况,我们所说的游标都是指显式游标。
要在程序中使用游标,必须首先声明游标。
声明游标语法关键词:显式游标当查询返回结果超过一行时,就需要一个显式游标,此时用户不能使用select into语句。
PL/SQL管理隐式游标,当查询开始时隐式游标打开,查询结束时隐式游标自动关闭。
显式游标在PL/SQL块的声明部分声明,在执行部分或异常处理部分打开,取出数据,关闭。
使用游标这里要做一个声明,我们所说的游标通常是指显式游标,因此从现在起没有特别指明的情况,我们所说的游标都是指显式游标。
要在程序中使用游标,必须首先声明游标。
声明游标语法:在PL/SQL中游标名是一个未声明变量,不能给游标名赋值或用于表达式中。
例:在游标定义中SELECT语句中不一定非要表可以是视图,也可以从多个表或视图中选择的列,甚至可以使用*来选择所有的列。
打开游标使用游标中的值之前应该首先打开游标,打开游标初始化查询处理。
打开游标的语法是:cursor_name是在声明部分定义的游标名。
例:OPEN C_EMP; 关闭游标。
语法:CLOSE cursor_name例:CLOSE C_EMP; 从游标提取数据。
从游标得到一行数据使用FETCH命令。
每一次提取数据后,游标都指向结果集的下一行。
语法如下:FETCH cursor_name INTO variable[,variable,...]对于SELECT定义的游标的每一列,FETCH变量列表都应该有一个变量与之相对应,变量的类型也要相同。
例:这段代码无疑是非常麻烦的,如果有多行返回结果,可以使用循环并用游标属性为结束循环的条件,以这种方式提取数据,程序的可读性和简洁性都大为提高,下面我们使用循环重新写上面的程序:记录变量定义一个记录变量使用TYPE命令和%ROWTYPE,关于%ROWsTYPE的更多信息请参阅相关资料。
记录变量用于从游标中提取数据行,当游标选择很多列的时候,那么使用记录比为每列声明一个变量要方便得多。
关键词:当在表上使用%ROWTYPE并将从游标中取出的值放入记录中时,如果要选择表中所有列,那么在SELECT子句中使用*比将所有列名列出来要得多。
例:%ROWTYPE也可以用游标名来定义,这样的话就必须要首先声明游标:带参数的游标与存储过程和函数相似,可以将参数传递给游标并在查询中使用。
这对于处理在某种条件下打开游标的情况非常有用。
它的语法如下:定义参数的语法如下:与存储过程不同的是,游标只能接受传递的值,而不能返回值。
参数只定义数据类型,没有大小。
另外可以给参数设定一个缺省值,当没有参数值传递给游标时,就使用缺省值。
游标中定义的参数只是一个占位符,在别处引用该参数不一定可靠。
在打开游标时给参数赋值,语法如下:参数值可以是文字或变量。
例:游标FOR循环在大多数时候我们在设计程序的时候都遵循下面的步骤:1、打开游标。
2、开始循环。
3、从游标中取值。
4、那一行被返回。
5、处理。
6、关闭循环。
7、关闭游标。
可以简单的把这一类代码称为游标用于循环。
但还有一种循环与这种类型不相同,这就是FOR循环,用于FOR循环的游标按照正常的声明方式声明,它的优点在于不需要显式的打开、关闭、取数据,测试数据的存在、定义存放数据的变量等等。
游标FOR循环的语法如下:关键词:下面我们用for循环重写上面的例子:在游标FOR循环中使用查询在游标FOR循环中可以定义查询,由于没有显式声明所以游标没有名字,记录名通过游标查询来定义。
游标中的子查询语法如下:可以看出与SQL中的子查询没有什么区别。
游标中的更新和删除在PL/SQL中依然可以使用UPDATE和DELETE语句更新或删除数据行。
显式游标只有在需要获得多行数据的情况下使用。
PL/SQL提供了仅仅使用游标就可以执行删除或更新记录的方法。
UPDATE或DELETE语句中的WHERE CURRENT OF子串专门处理要执行UPDATE或DELETE操作的表中取出的最近的数据。
要使用这个方法,在声明游标时必须使用FOR UPDATE子串,当对话使用FOR UPDATE子串打开一个游标时,所有返回集中的数据行都将处于行级(ROW-LEVEL)独占式锁定,其他对象只能查询这些数据行,不能进行UPDATE、DELETE或SELECT...FOR UPDATE操作。
语法:在多表查询中,使用OF子句来锁定特定的表,如果忽略了OF子句,那么所有表中选择的数据行都将被锁定。
如果这些数据行已经被其他会话锁定,那么正常情况下ORACLE将等待,直到数据行解锁。
在UPDATE和DELETE中使用WHERE CURRENT OF子串的语法如下:WHERE{CURRENT OF cursor_name|search_condition}关键词:DELCARECURSOR c1 IS SELECT empno,salary FROM empWHERE comm IS NULLFOR UPDATE OF comm;v_comm NUMBER(10,2);BEGINFOR r1 IN c1 LOOPIF r1.salary<500 THENv_comm:=r1.salary*0.25;ELSEIF r1.salary<1000 THENv_comm:=r1.salary*0.20;ELSEIF r1.salary<3000 THENv_comm:=r1.salary*0.15;ELSEv_comm:=r1.salary*0.12;END IF;UPDATE emp;SET comm=v_commWHERE CURRENT OF c1l;END LOOP;END:在PL/SQL中游标名是一个未声明变量,不能给游标名赋值或用于表达式中。
例:在游标定义中SELECT语句中不一定非要表可以是视图,也可以从多个表或视图中选择的列,甚至可以使用*来选择所有的列。
打开游标使用游标中的值之前应该首先打开游标,打开游标初始化查询处理。
打开游标的语法是:cursor_name是在声明部分定义的游标名。
例:OPEN C_EMP; 关闭游标。
语法:CLOSE cursor_name例:CLOSE C_EMP; 从游标提取数据。
从游标得到一行数据使用FETCH命令。
每一次提取数据后,游标都指向结果集的下一行。
语法如下:FETCH cursor_name INTO variable[,variable,...]对于SELECT定义的游标的每一列,FETCH变量列表都应该有一个变量与之相对应,变量的类型也要相同。
例:这段代码无疑是非常麻烦的,如果有多行返回结果,可以使用循环并用游标属性为结束循环的条件,以这种方式提取数据,程序的可读性和简洁性都大为提高,下面我们使用循环重新写上面的程序:记录变量定义一个记录变量使用TYPE命令和%ROWTYPE,关于%ROWsTYPE的更多信息请参阅相关资料。
记录变量用于从游标中提取数据行,当游标选择很多列的时候,那么使用记录比为每列声明一个变量要方便得多。
关键词:当在表上使用%ROWTYPE并将从游标中取出的值放入记录中时,如果要选择表中所有列,那么在SELECT子句中使用*比将所有列名列出来要得多。
例:%ROWTYPE也可以用游标名来定义,这样的话就必须要首先声明游标:带参数的游标与存储过程和函数相似,可以将参数传递给游标并在查询中使用。
这对于处理在某种条件下打开游标的情况非常有用。
它的语法如下:定义参数的语法如下:与存储过程不同的是,游标只能接受传递的值,而不能返回值。
参数只定义数据类型,没有大小。
另外可以给参数设定一个缺省值,当没有参数值传递给游标时,就使用缺省值。
游标中定义的参数只是一个占位符,在别处引用该参数不一定可靠。
在打开游标时给参数赋值,语法如下:参数值可以是文字或变量。
例:游标FOR循环在大多数时候我们在设计程序的时候都遵循下面的步骤:1、打开游标。
2、开始循环。
3、从游标中取值。
4、那一行被返回。
5、处理。
6、关闭循环。
7、关闭游标。
可以简单的把这一类代码称为游标用于循环。
但还有一种循环与这种类型不相同,这就是FOR循环,用于FOR循环的游标按照正常的声明方式声明,它的优点在于不需要显式的打开、关闭、取数据,测试数据的存在、定义存放数据的变量等等。
游标FOR循环的语法如下:关键词:下面我们用for循环重写上面的例子:在游标FOR循环中使用查询在游标FOR循环中可以定义查询,由于没有显式声明所以游标没有名字,记录名通过游标查询来定义。
游标中的子查询语法如下:可以看出与SQL中的子查询没有什么区别。
游标中的更新和删除在PL/SQL中依然可以使用UPDATE和DELETE语句更新或删除数据行。
显式游标只有在需要获得多行数据的情况下使用。
PL/SQL提供了仅仅使用游标就可以执行删除或更新记录的方法。
UPDATE或DELETE语句中的WHERE CURRENT OF子串专门处理要执行UPDATE或DELETE操作的表中取出的最近的数据。
要使用这个方法,在声明游标时必须使用FOR UPDATE子串,当对话使用FOR UPDATE子串打开一个游标时,所有返回集中的数据行都将处于行级(ROW-LEVEL)独占式锁定,其他对象只能查询这些数据行,不能进行UPDATE、DELETE或SELECT...FOR UPDATE操作。
语法:在多表查询中,使用OF子句来锁定特定的表,如果忽略了OF子句,那么所有表中选择的数据行都将被锁定。
如果这些数据行已经被其他会话锁定,那么正常情况下ORACLE将等待,直到数据行解锁。
在UPDATE和DELETE中使用WHERE CURRENT OF子串的语法如下:WHERE{CURRENT OF cursor_name|search_condition}关键词:DELCARECURSOR c1 IS SELECT empno,salaryFROM empWHERE comm IS NULLFOR UPDATE OF comm;v_comm NUMBER(10,2); BEGINFOR r1 IN c1 LOOPIF r1.salary<500 THENv_comm:=r1.salary*0.25; ELSEIF r1.salary<1000 THEN v_comm:=r1.salary*0.20; ELSEIF r1.salary<3000 THEN v_comm:=r1.salary*0.15; ELSEv_comm:=r1.salary*0.12; END IF;UPDATE emp;SET comm=v_commWHERE CURRENT OF c1l;END LOOP; END。