㈠ Oracle存储过程和游标操作
sql">--第一个题目,我的表叫stu,你别忘了改成你的表名
createorreplaceprocerepro7
as
cursorc_emp1isselectename,salfromstu;
venamestu.ename%type;
vsalstu.sal%type;
vnewsalstu.sal%type;
vfdnumber:=0;
begin
openc_emp1;
loop
fetchc_emp1intovename,vsal;
exitwhenc_emp1%notfound;
vfd:=vsal*0.2;
ifvfd<=300
thenupdatestusetsal=sal+vfdwhereename=vename;
vnewsal:=vsal+vfd;
dbms_output.put_line('员工'||vename||'涨了'||vnewsal||'工资');
endif;
endloop;
closec_emp1;
end;
㈡ oracle 存储过程 游标
select isnull(a.姓名, b.姓名), a.手机号, isnull(a.身份证号, b.身份证号),isnull(a.住址, b.住址)
from 表1 a, 表2 b
where a.手机号=b.手机号
㈢ oracle怎样用游标调用存储过程
这个需要用程序包package来做。在包头里定义入参为游标
createorreplace
PACKAGEpro_test
AS
TYPECURSOR_PAGEISREFCURSOR;
PROCEDUREinsert_one_teacher(
p_1INCURSOR_PAGE);
END;
后面包体就不列了。
㈣ oracle存储过程游标问题
--打开游标并提取后面SQL的第一行数据放到游标中 这里就是打开游标
open for 是隐式游标的写法 不建议使用 这种游标好象不需要关闭 具体你自己测试下 而且少了expection 处理
fetch mycur into yang_02;
--循环插入数据
多余了 可以不要 前面有fetch了如果还有这里的话 就只能插入奇数行
其他没什么问题了 还有你这个过程用ref cursor是浪费 没必要用 用简单的显示游标更好点
㈤ oracle存储过程游标有什么用
1,什么是游标?
①从表中检索出结果集,从中每次指向一条记录进行交互的机制。
②关系数据库中的操作是在完整的行集合上执行的。
由SELECT 语句返回的行集合包括满足该语句的WHERE 子句所列条件的所有行。由该语句返回完整的行集合叫做结果集。
应用程序,尤其是互动和在线应用程序,把完整的结果集作为一个单元处理并不总是有效的。
这些应用程序需要一种机制来一次处理一行或连续的几行。而游标是对提供这一机制的结果集的扩展。
游标是通过游标库来实现的。游标库是常常作为数据库系统或数据访问API 的一部分而得以实现的软件,
用来管理从数据源返回的数据的属性(结果集)。这些属性包括并发管理、在结果集中的位置、返回的行数,
以及是否能够在结果集中向前和/或向后移动(可滚动性)。
游标跟踪结果集中的位置,并允许对结果集逐行执行多个操作,在这个过程中可能返回至原始表,也可能不返回至原始表。
换句话说,游标从概念上讲基于数据库的表返回结果集。
由于它指示结果集中的当前位置 ,就像计算机屏幕上的光标指示当前位置一样,“游标”由此得名。
㈥ oracle存储过程中定义游标
放到begin里面不要declare,在过程和函数里面申明变量貌似不要declare,否则会报错
㈦ oracle在存储过程中定义游标
createorreplace
procerepro6
as
vempnoemp.empno%type;
venameemp.ename%type;
cursorc_empisselectempno,enamefromemp;
begin
openc_emp;
loop
fetchc_empintovempno,vename;
exitwhenc_emp%notfound;
dbms_output.put_line('编号:'||vempno||'姓名:'||vename);
endloop;
closec_emp;
end;