游标你们记得,它是处理多行数据的,有点类似于集合里面的迭代器一样,一条条给你遍历打印一下,这个也是给他取出一条条的数据,就要使用到游标14. 利用游标, 调整公司中员工的工资: 工资范围       调整基数0 - 5000       5%5000 - 10000   3%10000 - 15000  2%15000 -        1%declare--定义游标cursor emp_sal_cursor is select salary, employee_id from employees;--定义基数变量temp number(4, 2);--定义存放游标值的变量v_sal employees.salary%type;v_id employees.employee_id%type;
begin--打开游标open emp_sal_cursor;--提取游标fetch emp_sal_cursor into v_sal, v_id;--处理游标的循环操作while emp_sal_cursor%found loop--判断员工的工资, 执行 update 操作--dbms_output.put_line(v_id || ': ' || v_sal);if v_sal <= 5000 thentemp := 0.05;elsif v_sal<= 10000 thentemp := 0.03;   elsif v_sal <= 15000 thentemp := 0.02;elsetemp := 0.01;end if;--dbms_output.put_line(v_id || ': ' || v_sal || ', ' || temp);update employees set salary = salary * (1 + temp) where employee_id = v_id; fetch emp_sal_cursor into v_sal, v_id;end loop;--关闭游标close emp_sal_cursor;
end;使用SQL中的 decode 函数update employees set salary = salary * (1 + (decode(trunc(salary/5000), 0, 0.05,1, 0.03,2, 0.02,0.01)))利用游标,调整公司中员工的工资,工资的范围,还有调整所有员工的工资,有多条数据了,所以要用游标,除了游标之外,是不是还要定义其他的变量,比如我们的SQL写的比较熟了,假设他要调整公司的工资的话,就这样写,update,employees,然后set一个salary,等于salary加上一个工资范围,那得乘以一个,1加上一个百分比,百分之几我们用一个变量来表示,这个变量怎么得到的,你后边加上一个什么什么东西,然后where跟他对应的是哪一个人,百分之三,0.03,然后where,对于102这个人来讲,这个人是加0.03,换个人是0.05,所以这是一个变量,这也应该是一个变量,这个变量,随着这个变量的人的不同,然后这个salary,因为你要想得到这个0.03,这个你要是想不到的话,你可以去写,你发现这个变量如果不够用了,你就再来声明呗,就可以,declare声明,先是多个员工,多个员工可以使用到游标,游标emp_sal_cursor,前面加上一个cursor,is select,我这要获取哪些信息,这个你要是没想到的话你可以先写,不够的话再来补,salary from employees,这是声明一个游标,然后呢每个人,获取哪些信息,这个你要是没想到的话你就先写,不够的话再来补,工资按照标准来调,我用一个变量来记录一下,每个人调整的幅度是多少,number类型的,也是两个小数,另外呢,我查询出来的employee_id,salary,我得用两个变量来存,v_empid,employees的employee_id,同时还有一个salary,这是我们声明的几个变量,然后这个变量是调整的基数,用于记录调整基数,你把查询的放到这里边,这是declare,然后begin,要做的,关于游标,open,打开游标,获取游标,fetch,into,放到两个变量里,v_empid,这里先写的id,后写的salary,fetch,into他,while,found有数据,然后进行一个循环,执行一个循环,如果,如果什么啊,v_sal是小于,不包括5000,then,v_temp冒号等于,0.05,elsif,那就是这个,小于1万,v_temp等于0.03,else,最后一个,v_temp,0.01,这个完了以后,end if,结束这条件判断,我通过这个条件判断,记录一下v_temp的值是多少,下一步,没执行一次他,需要更新一个人,那我们这个时候就要写一个SQL语句,update employees,然后呢,set salary等于,salary*(1+v_temp),然后where employee_id等于v_empid,这个是成对出现的,调整的是这个人的工资,这就是被他更新了一条,更新完了一条以后,别忘了这个while循环,还得再fetch一下,fetch完了以后,end loop,然后end结束,close,当然没啥效果,先rollback一下,我打印一下这个v_sal,调整完以后,这个v_sal是变量的,你想打印salary的,还得重新给他赋一个值,否则我们看不到新的值,就是旧的employee_id和salary,这是旧的,update employeesselect * from employees;

rollback就回滚了

这个我们写的也没有问题,如果我就不用PL/SQL语言去update,用SQL能不能实现,也能,SQL也能实现,update这个表里边的,工资改成什么,要看这个人的工资是多少了,我们这里也是一个条件语句,定义了decode,这个是我们之前就能写的,把这个salary除以5000一比,然后trunc一下得到一个值,看这个值是0的话,存到0.05,1的是1万,存到0.03,然后salary加上1的值,这是使用的是SQL,用游标for完成刚才的1415. 利用游标 for 循环完成 14. declare--定义游标cursor emp_sal_cursor is select salary, employee_id id from employees;--定义基数变量temp number(4, 2);
begin--处理游标的循环操作for c in emp_sal_cursor loop--判断员工的工资, 执行 update 操作--dbms_output.put_line(v_id || ': ' || v_sal);if c.salary <= 5000 thentemp := 0.05;elsif c.salary <= 10000 thentemp := 0.03;   elsif c.salary <= 15000 thentemp := 0.02;elsetemp := 0.01;end if;--dbms_output.put_line(v_id || ': ' || v_sal || ', ' || temp);update employees set salary = salary * (1 + temp) where employee_id = c.id;end loop;
end;游标for的区别就是,打开关闭,自动的去fetch,他自己就可以完成了,大家看,for,取一个变量叫c,然后in,loop,c现在直接指向的是employees的salary,实际上这两个变量也用不着了,如果c.salary,它是小于5000的,然后then,就这样处理,elsif,c.salary,end if结束他,update他,然后salary等于他,这个得改一下,c.employee_id,就这样写,然后update完了以后,end loopdeclarecursor emp_sal_cursor is select employee_id,salary from employees;v_temp number(4,2);beginfor c in emp_sal_cursor loopif c.salary < 5000 then v_temp := 0.05;elsif c.salary < 10000 then v_temp := 0.03;elsif c.salary < 15000 then v_temp := 0.02;else v_temp := 0.01;end if;update employeesset salary = salar * (1+ v_temp)where employee_id = c.employee_id;end loop;end;


显然使用for循环来处理要简单一些,带参数的游标16*. 带参数的游标declare--定义游标cursor emp_sal_cursor(dept_id number, sal number) is select salary + 1000 sal, employee_id id from employees where department_id = dept_id and salary > sal;--定义基数变量temp number(4, 2);
begin--处理游标的循环操作for c in emp_sal_cursor(sal => 4000, dept_id => 80) loop--判断员工的工资, 执行 update 操作--dbms_output.put_line(c.id || ': ' || c.sal);if c.sal <= 5000 thentemp := 0.05;elsif c.sal <= 10000 thentemp := 0.03;   elsif c.sal <= 15000 thentemp := 0.02;elsetemp := 0.01;end if;dbms_output.put_line(c.sal || ': ' || c.id || ', ' || temp);--update employees set salary = salary * (1 + temp) where employee_id = c.id;end loop;
end;这个了解一下,什么叫代参数的游标,我们不是声明一个游标吗,这个游标的名字,我直接is select,这里我写了两个变量,这个变量是记录dept的id,那就是部门id,比较类似于局部变量,salary也是一个number类型的,然后我在这个select语句当中,使用了这两个变量,当你真正在调用这个cursor的时候,我只能用两个变量的值,要不是这样我们就写到这儿了,比如说啊,select salary加上1千,employee_id,from他,department_id等于我这个变量,然后salary还要大于多少,你要是不在这写的话,直接放到这就相当于写死了,这个就是动态的,当你调用的时候,这个就是我们说的赋值符号,表示给他赋值,salary,这个是80号部门的,再下面的调用是一样的,没啥区别,只是select语句写成变量了
17. 隐式游标: 更新指定员工 salary(涨工资 10),如果该员工没有找到,则打印”查无此人” 信息beginupdate employees set salary = salary + 10 where employee_id = 1005;if sql%notfound thendbms_output.put_line('查无此人!');end if;
end;有个叫隐式游标,有显示游标,还有叫隐式游标,这个你也了解一下,隐式游标肯定不需要你显示的cursor定义一下,直接相当于就可以用,这个怎么来理解,如果员工没找到,打印没此人,直接begin,更新update,employees,set salary等于salary加上10,指定员工的employee_id等于101,然后我再加上这个,如果这个员工没找着,判断是一个SQL语句,如果SQL语句定义的记录没有找着,notfound,有found也有notfound,如果没找着,就then,打印查无此人,然后end if,结束,这里面实际上用到这个了,执行成了,说明有这个人beginupdate employeesset salary = salary + 10where employee_id = 101;if sql%notfound then dbms_output.put_line('查无此人');end if;end;

beginupdate employeesset salary = salary + 10where employee_id = 1001;if sql%notfound then dbms_output.put_line('查无此人');end if;end;

通过它来理解一下,它是叫隐式游标,他没有显示的定义,但是这个是个SQL语句,我通过判断SQL语句,是否存在这个值,返回这个结果,有一条数据,判断是否执行这个语句,这个叫隐式游标,那么游标讲到这就完了,你们知道我们用游标来做什么,如果你要处理多行数据的话,增删改查,如果涉及到多行数据,多条数据,我们就给他定义成游标,的形式

plsql(轻量版)_游标的使用2相关推荐

  1. plsql(轻量版)_游标的使用1

    叫游标的使用,游标,以前没有听过这个名,什么是游标,他的作用是什么,如何来声明,怎么来使用,主要是你要掌握他是干嘛的,怎么用,游标,在PL/SQL程序当中,对于处理多行记录的事务,经常使用游标来实现, ...

  2. plsql(轻量版)_基本语法

    ORACLE的组件也可以用PL/SQL去写,后边有存储过程,存储函数,触发器,可以自己来写存储过程,或者叫触发器,那前面有哪些我们就走一走,这里实际上是一本小书了,59页,比较经典版的plsql,我们 ...

  3. plsql(轻量版)_异常处理机制

    一个优秀的程序都应该能够正确的处理各种出错异常,并尽可能的从错误中恢复,ORACLE提供异常来实现错误处理,异常exception这个词还是这个,处理正常执行过程中未预料的事件,他分为预定义的错误,和 ...

  4. plsql(轻量版)_流程控制

    记录类型百分号type,使用它的优点,所引用的数据库列的数据类型不必知道,要不你就得知道它的类型和他的一样的,这里你可以实时改变,列的数据类型改变,我这里也跟着改,动态的来获取你的类型 这里还有个百分 ...

  5. plsql(轻量版)_记录类型2

    PL/SQL这一块,整个这一块需要大家掌握什么,就是他基本的格式,PL/SQL,基本的语法格式,如何声明一个变量,然后程序从哪里执行,执行的格式是什么,出现异常怎么处理,基本的语法格式,就这样写吧,第 ...

  6. plsql(轻量版)_触发器

    触发器是许多关系型数据库系统都提供的一项技术,在ORACLE系统里,触发器类似过程和函数,都有声明,执行和异常处理过程的PL/SQL块,这是他创建的一个格式,这个触发器的作用是什么,触发器以独立的对象 ...

  7. plsql(轻量版)_记录类型1

    定义变量,变量类型的,这个是可变的 这里涉及到一个概念叫记录类型,记录类型是把逻辑相关的数据作为一个单元存储起来,称作一个record,其作用是存储互不相同但逻辑相关的信息,这个叫记录类型,这个是以什 ...

  8. plsql轻量版游标的使用2

  9. plsql轻量版游标的使用

最新文章

  1. Windows 10安装Tensorflow
  2. Project Management - 3) Manage Your Meetings
  3. MQ和RabbitMQ作用特点
  4. MATLAB从入门到精通-如何在MATLAB中实现各种特殊上标?
  5. Kinect学习(一):开发环境搭建
  6. python作用域-Python之函数作用域
  7. 基于原始套接字的嗅探器
  8. 从编码层面对比java和c#
  9. 智慧交通day03-车道线检测实现05:透视变换+代码实现
  10. Android官方开发文档Training系列课程中文版:线程执行操作之线程池操作
  11. 研究生第一篇学术论文常犯问题总结
  12. Nmap 源代码学习四 软件简单使用
  13. 解决VS2003查询卡死的问题
  14. ADI超声解决方案 和系统成像设计
  15. MARIADB数据库服务器
  16. ADP论文关键要点总结
  17. 从零到百亿互网融构展
  18. 使用AMD CPU,打造自己的深度学习服务器
  19. 【redis】redis内存达到上限的处理方法
  20. 【大数据】数据驱动的大数据金融应用-2017CCTC大会-专题视频课程

热门文章

  1. ZOJ 1610 Count the Colors (线段树区间更新)
  2. ADO.NET2.0的十大新特性
  3. 【struts2】struts2中对象的获取
  4. 曾经想学很多很多,最后发现自己只能专心学那么很少的几个必杀技
  5. 记录一次dubbo项目实战
  6. date -d的灵活应用
  7. SQL Server 2005无法输入中文的解决方案
  8. MyBatis对于Java对象里的枚举类型处理
  9. 阿里云容器服务体验: 部署 ShellPays 条码支付整合服务平台 -- (四)结案陈词
  10. excel合并同类项数据求和