项目生命周期:

瀑布模型

拿到一个项目后,首先:分析需要用到的SQL语句;

其次:分析需要定义的变量初始值是多少,怎么得到最终值;

案例一:

统计每年入职的员工数量以及总数量:

  SQL语句:select to_char(hiredate,'yyyy') from emp;--to_char(hiredate,'yyyy') :hiredate原本的格式是yyyy-mm-dd但是我们只需要年份,则强制转换为char型,并且格式为yyyy,强制转换语法:to_                       目的类型(目标字段,格式)

需要遍历整个表,那么需要用到光标->循环->退出条件:%notfound

变量:phiredate varchar2(20)

计数器:

count80 number := 0;

count82 number := 0;

count87 number := 0;

count89 number := 0;

set serveroutput on;

declare

cursor c is select  to_char(hiredate,'yyyy') from emp;--定义光标

phiredate varchar2(20);

count80 number := 0;

count82 number := 0;

count87 number := 0;

count89 number := 0;

begin

open c;--打开光标

loop

fetch c into phiredate ;--取出员工的入职年份

exit when c%notfound;--关闭循环的条件

if phiredate= '1980'  then   count80 number := count80+ 1;

elsif  phiredate= '1982'  then   count82 number := count82+ 1;

elsif  phiredate= '1987'  then   count87 number := count87+ 1;

else     count87 number := count87+ 1;

end if;

end loop;

close c;

dbms_output.put_line('tatal:'||count80+count82+count87+count89)

end;

/

案例二

  SQL语句:select no,sal from emp;

需要遍历整个表,那么需要用到光标->循环->退出条件:%notfound

变量:pno emp.no%type;

psal emp.sal%type;

涨工资人数:countemp number := 0;

涨后的工资总额:saltotal number;

select sum(sal) into saltotal from emp;

涨后的工资总额 = 涨前的工资总额 + sal*0.1;

set serveroutput on

declare

cursor c is select empno,sal from order by sal;

pno emp.no%type;

psal emp.sal%type;

countemp number := 0;--涨工资的人数

saltatol number;--涨后的工作总额

begin

select sum(sal) into saltatol from emp;--涨工资前的初始值

open c;

loop

exit when saltotal >50000;

fetch c into pno,psal;

exit when c%notfound;

update emp set sal := sal*1.1 where no = pno;--涨工资

countemp :=  countemp + 1;--人数+1

end loop;

close c;

commit;

dbms_output.out_put('人数= '||countepm||',涨后的工资总额:'||saltatol);

end:

/

案例三

实现部门分段(6000分以上,6000》且3000《,3000以下)统计各工资段的职工人数,以及各部门的工资总额(不包括奖金)

首先需要创建存储结果的表msg:create table msg(deptno number;count1 number;count2 number;  count3 number;saltotal number);

set serveroutput on

declare

cursor cdept is select deptno from dept;--部门的光标

pdeptno dept.deptno %type;--部门光标对应的变量

cursor cemp(deptno) is select sal from emp where no = deptno;--部门工资的光标

psal emp.sal %type;--部门工资光标对应的变量

count1 number;count2 number;count3 number;--每个阶段员工计数器

begin

open cdept;

loop

fetch cdept into pdeptno;--取出一个部门

exit when cdepy%notfound;

count1 :=0;count2 :=0;count3 :=0;--初始化计数器

select sum(sal) into saltatol from emp where deptno = pdeptno;--计算部门工资总额

open cemp(pdeptno)

loop

fetch cemp into psal;--取出每一个员工的薪资

exit when cemp%noufound;

if psal <3000 then count1 := count1 +1;--判断工资范围

elsif  psal>6000 then count3 := count3 +1;

else count2 := count2 +1;

end if;

end loop;

close cemp;

insert into  msg value(pdeptno,count1,count2,count3,saltatol);--保存当前部门的结果

end loop;

close cdept;

end:

/

案例四

按照系分段统计(成绩小于60,大于85,中间段)课程为‘大学物理’各个分数段的学生人数,以及各系学生的平均成绩;

set serveroutput on

declare

cersor cdept is select dno ,dname from dep;

pdno dep.dno%type;

cursor cgrade(coursename varchar2,depno number) is select grade from sc where cno =  (select cno from course where cname = courname) and sno in (select sno from student where dno = depno)--成绩光标

pgrade sc.grade % type;

count1 number;count2 number;count3 number;--每个分数段人数计数器

avggrade number;--平均成绩

pcoursename varchar2 :='大学物理';

begin

open cdept;

loop

fetch cdept into pdno,pdname;

exit when cdept%notfound;

count1 :=0;count2 :=0;count3 :=0;--初始化计数器

select avg(grade) into avggrade from sc where cno =  (select cno from course where cname = courname) and sno in (select sno from student where dno = depno)

open cgrade (pcoursename,pdno);

loop

fetch cgrade into pgrade;

exit when cgrade %notfound;

if psal <60 then count1 := count1 +1;--判断工资范围

elsif  psal>85 then count3 := count3 +1;

else count2 := count2 +1;

end if;

end loop;

end loop;

close cgrade;

insert into msg value (pcoursename,count1,count2,count3,avggrade);

end loop;

close cdept;

commit;

dbms_output.put_line('统计完成');

end:/

pl/sql案例的更多相关文章

  1. Oracle+PL+SQL从入门到精通.丁士锋.清华大学出版社.2012

    \t第1篇 pl/sql开发入门第1章 oracle 11g数据库系统1.1 关系型数据库系统介绍1.1.1 什么是关系型数据模型1.1.2 数据库系统范式1.1.3 关系型数据库管理系统1.1.4 ...

  2. PL/SQL重新编译包无反应案例2

    在这篇"PL/SQL重新编译包无反应"里面介绍了编译包无反应的情况,今天又遇到一起案例, 在测试环境中,一个包的STATUS为INVALID,重新编译时,一直处于编译状态,检查发现 ...

  3. PL/SQL中的变量案例解析

    1.标量: ag1: declare v_ename emp.ename%type;--自己称为单变量 begin select ename into v_ename from emp where e ...

  4. 百倍性能的PL/SQL优化案例(r11笔记第13天)

    我相信你是被百倍性能的字样吸引了,不过我所想侧重的是优化的思路,这个比优化技巧更重要,而结果嘛,其实我不希望说成是百倍提升,“”自黑“”一下. 有一个真实想法和大家讨论一下,就是一个SQL语句如果原本 ...

  5. Oracle PL/SQL随堂笔记总结

    1.pl/sql编程 2.存储过程 3.函数 4.触发器 5.包 6.pl/sql基础 -定义并使用变量 7.pl/sql的进阶 8.oracle的视图 1.pl/sql编程 1.理解oracle的p ...

  6. 每周一书《Oracle 12 c PL(SQL)程序设计终极指南》

    本周为大家送出的书是<Oracle 12 c PL(SQL)程序设计终极指南>,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著. 内容简介: <Oracle 12c PL/SQ ...

  7. 历尽磨难之PL/SQL链接Oracle数据库

    说起来都是泪啊,上司布置的任务需要远程连接Oracle数据库,说实话这又是我人生中的第一次.我听到以后觉得不是什么大问题,然而我错了..错的很厉害! 我搞了一天一夜才弄好,这里面原因有很多,大体来讲还 ...

  8. ORACLE PL/SQL编程详解

    ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...

  9. Oracle数据库之PL/SQL基础

    介绍PL/SQL之前,先介绍一个图像化工具:Oracle SQL Developer 在oracle的开发过程中, 我们难免会使用第三方开发的软件来辅助我们书写SQL, pl/sql是一个不错的sql ...

随机推荐

  1. Java实现 POJ 2749 分解因数(计蒜客)

    POJ 2749 分解因数(计蒜客) Description 给出一个正整数a,要求分解成若干个正整数的乘积,即a = a1 * a2 * a3 * - * an,并且1 < a1 <= ...

  2. java实现取球游戏

    /* 今盒子里有 n 个小球,A.B 两人轮流从盒中取球,每个人都可以看到另一个人取了多少个, 也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断. 我们约定: 每个人从盒子中取出的球的 ...

  3. java实现黄金队列

    ** 黄金队列** 黄金分割数0.618与美学有重要的关系.舞台上报幕员所站的位置大约就是舞台宽度的0.618处,墙上的画像一般也挂在房间高度的0.618处,甚至股票的波动据说也能找到0.618的影子 ...

  4. java实现第五届蓝桥杯幂一矩阵

    幂一矩阵 天才少年的邻居 atm 最近学习了线性代数相关的理论,他对"矩阵"这个概念特别感兴趣.矩阵中有个概念叫做幂零矩阵.对于一个方阵 M ,如果存在一个正整数 k 满足 M^k ...

  5. IDEA连接远程服务器Docker部署Spring Boot项目

    开始前的准备工作 拥有一台云服务器,我的是腾讯云服务器(CentOS7) 腾讯云服务器安装Docker,我的版本是Docker 19.03.9,关于安装和配置镜像加速器可以查阅我的另一篇博文:http ...

  6. CDN HTTPS安全加速基本概念、解决方案及优化实践

    大家都知道,HTTP 本身是明文传输的,没有经过任何安全处理,网站HTTPS解决方案通过在HTTP协议之上引入证书服务,完美解决网站的安全问题.本文将为大家介绍阿里云CDN HTTPS安全加速传输的基 ...

  7. 哪些年,我们玩过的Git

    作者:玩世不恭的Coder公众号:玩世不恭的Coder时间:2020-06-05说明:本文为原创文章,未经允许不可转载,转载前请联系作者 哪些年,我们玩过的Git 前言一.前期工作常用基本概念的理解G ...

  8. ESXI多网卡网络配置

    1.两台路由器接入不同网络: 2.一台4网口服务器,网口分别为:vmnic0.vmnic1.vmnic2.vmnic3 3.ESXI6.5服务器虚拟机系统 测试环境模拟: 路由1:192.168.0. ...

  9. 如何解决ubuntu 12.04重启后出现waiting for network configuration和网络标志消失问题

    如何解决ubuntu 12.04重启后出现waiting for network configuration和网络标志消失问题 作为菜鸟的我在学着设置网络后,重启电脑后显示 waiting forne ...

  10. void out2() const{

    include "stdafx.h" include using namespace std; class aa{ int num; public: aa(){ int b =10 ...