1、编写一个存储过程,根据输入的工作类型,输出该工作的平均工资。

命令如下:

创建存储过程:

create or replace procedure avgsal(v_job in emp.job%type)
is
avgsal2 number
begin
select avg(sal) into avgsal2 from emp where job=v_job;
dbms_output.put_line(v_job || '---' || avgsal2)
end;
调用存储过程:

Begin
avgsal('MANAGER');
end;
程序截图:

运行结果:

2、创建一个存储过程,以员工号为参数,输出该员工的工资。

命令如下:

创建存储过程:

create or replace procedure p_sxtl(v_empno in emp.empno%type,v_sal out emp.sal%type)
is
begin
select sal into v_sal from emp where empno=v_empno;
end;
调用存储过程:

declare
v_empno emp.empno%type :=7369;
v_sal emp.sal%type;
begin
p_sxtl(v_empno,v_sal);
dbms_output.put_line(v_empno || '员工的工资为:' || v_sal);
end;
程序截图:

运行结果:

3、创建一个存储过程,以员工号为参数,修改该员工的工资。若该员工属于10号部门,则工资增加150;若属于20号部门,则工资增加200;若属于30号部门,则工资增加250;--若属于其他部门,则增加300。

命令如下:

创建存储过程:

create or replace procedure p_sxt2(v_empno in emp.empno%type)
is
v_deptno emp.deptno%type;
v_sal emp.sal%type;
Begin
select deptno into v_deptno from emp where empno=v_empno;
select sal into v_sal from emp where empno=v_empno;
dbms_output.put_line(v_empno || '的部门是' || v_deptno || '修改前的工资是' || v_sal);
case v_deptno
when 10 then update emp set sal=sal+150 where empno=v_empno;
when 20 then update emp set sal=sal+200 where empno=v_empno;
when 30 then update emp set sal=sal+250 where empno=v_empno;
else update emp set sal=sal+300 where empno=v_empno;
end case;
select sal into v_sal from emp where empno=v_empno;
dbms_output.put_line(v_empno || '部门是' || v_deptno || '修改后的工资是:' || v_sal);
commit;
end;
调用存储过程:

begin
p_sxt2(7369);
end;
程序截图:

运行结果:

3、创建一个函数,以员工号为参数,返回该员工的工资。

命令如下:

创建函数:

create or replace function f_sxtl(v_empno in emp.empno%type,v_sal out emp.sal%type)
return emp.sal%type
as
begin
select sal into v_sal from emp where empno=v_empno;
return v_sal;
end;
调用函数:

Begin
:result := f_sxtl(7369,v_sal => :v_sal);
end;
程序截图:

运行结果:

4、创建一个函数,以员工号为参数,返回该员工所在的部门的平均工资。

命令如下:

创建函数:

create or replace function avegsal(v_empno in emp.empno%type)
return emp.sal%type
as
avgsal2 emp.sal%type;
begin
-- Test statements here
select avg(sal) into avgsal2 from emp where deptno = (select deptno from emp where empno=v_empno);
return avgsal2;
end;
调用函数:

begin
:result := avegsal(7369);
end;
程序截图:

运行结果:

5、创建一个存储过程,以员工号和部门号作为参数,修改员工所在的部门为所输入的部门号。如果修改成功,则显示“员工由……号部门调入调入……号部门”;如果不存在该员工,则显示“员工号不存在,请输入正确的员工号。”;如果不存在该部门,则显示“该部门不存在,请输入正确的部门号。”

命令如下:

创建存储过程:

create or replace procedure p_deptno(v_empno in emp.empno%type,v_deptno in emp.deptno%type)
as
vu_empno number := 0 ;
vu_deptno number :=0 ;
vm_deptno emp.deptno%type;
begin
select deptno into vm_deptno from emp where empno=v_empno;
select count(*) into vu_empno from emp where empno=v_empno;
select count(distinct deptno) into vu_deptno from emp where deptno=v_deptno;
if vu_empno=0 then dbms_output.put_line('员工号不存在,请输入正确的员工号.');
end if;
if vu_deptno=0 then dbms_output.put_line('该部门不存在,请输入正确的部门号.');
end if;
if vu_empno=1 and vu_deptno=1 then dbms_output.put_line('员工由' || vm_deptno || '号部门调入' || v_deptno || '号部门');
update emp set deptno=v_deptno where empno=v_empno;
commit;
end if;
end;
调用存储过程:

(1)begin
p_deptno(7369,40);
end;
(2)begin
p_deptno(7369,10);
end;
程序截图:

(2)

运行结果:

(1)

(2)

---------------------

PLSQL练习-数据共享与整合技术的更多相关文章

  1. 7:CSS Sprites的原理(图片整合技术)

    7:CSS Sprites的原理(图片整合技术) 一.将导航背景图片,按钮背景图片等有规则的合并成一张背景图,即将多张图片合为一张整图,然后用background-position”来实现背景图片的定 ...

  2. CSS Sprites的原理(图片整合技术)(CSS精灵)/雪碧图

    CSS Sprites的原理(图片整合技术)(CSS精灵)/雪碧图   一.将导航背景图片,按钮背景图片等有规则的合并成一张背景图,即将多张图片合为一张整图,然后用background-positio ...

  3. 统一门户与业务系统的sso整合技术方案(单点登录)

    一.单点登录(SSO,Single Sign On)整合目前计划接入统一门户的所有业务系统均为基于JavaEE技术的B/S架构系统.由于统一门户的单点登录技术选用的是JA-SIG组织开发的Cas Se ...

  4. springMVC:校验框架:多规则校验,嵌套校验,分组校验;ssm整合技术

    知识点梳理 课堂讲义 学习目标 能够阐述表单验证的分类和区别 能够运用表单验证的常用注解 能够编写表单验证的示例 能够编写SSM整合的应用案例 能够总结SSM整合的步骤 1 校验框架 1.1 入门-视 ...

  5. Spring 整合 Hibernate

    Spring 整合 Hibernate •Spring 支持大多数流行的 ORM 框架, 包括 Hibernate JDO, TopLink, Ibatis 和 JPA. •Spring 对这些 OR ...

  6. 王家林的81门一站式云计算分布式大数据&移动互联网解决方案课程第14门课程:Android软硬整合设计与框架揭秘: HAL&Framework &Native Service &App&HTML5架构设计与实战开发

    掌握Android从底层开发到框架整合技术到上层App开发及HTML5的全部技术: 一次彻底的Android架构.思想和实战技术的洗礼: 彻底掌握Andorid HAL.Android Runtime ...

  7. 大数据技术人年度盛事! BDTC 2016将于12月8-10日在京举行

    2016年12月8日-10日,由中国计算机学会(CCF)主办,CCF大数据专家委员会承办,中国科学院计算技术研究所和CSDN共同协办的2016中国大数据技术大会(Big Data Technology ...

  8. Android架构设计和软硬整合完整训练

    Android架构设计和软硬整合完整训练 Android架构设计和软硬整合完整训练:HAL&Framework&Native Service&Android Service&a ...

  9. Spring框架的第四天(整合ssh框架)

    ## Spring框架的第四天 ## ---------- **课程回顾:Spring框架第三天** 1. AOP注解方式 * 编写切面类(包含通知和切入点) * 开启自动代理 2. JDBC模板技术 ...

随机推荐

  1. IP地址库解析——读取IP地址获得实际地理位置信息的java源码实现

    说明:IP地址库来自QQwry.dat数据库文件,通过解析地址库当中的ip,已经细化最后获取的信息:获取ip地址对应的:国家 / 省 / 市 / 运营商ISP信息. 解析主要用到三个类: (1) IP ...

  2. Makefile研究(二)—— 完整可移植性模板

    转自:http://blog.csdn.net/jundic/article/details/17676461 一直想写一个很全很好移植的Makefile模板,我觉得一个完整makefile 应该包含 ...

  3. UVa 10214 Trees in a Wood. (数论-欧拉函数)

    题意:给定一个abs(x) <= a, abs(y) <= b,除了原点之外的整点各有一棵树,可以相互阻挡,求从原点可以看到多少棵树. 析:由于a < b,所以我们可以一列一列的统计 ...

  4. HDU - 4535 ZZULI 1867: 礼上往来【错位排序】

    1867: 礼上往来 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 216  Solved: 65 SubmitStatusWeb Board Desc ...

  5. 483. Smallest Good Base

    For an integer n, we call k>=2 a good base of n, if all digits of n base k are 1. Now given a str ...

  6. iOS集成支付宝支付

    本文由本人原创发表于博客园,转载请注明出处 http://www.cnblogs.com/wangqw/p/5074907.html 一. 开发前准备 iOS 支付宝SDK下载地址:(内含iOS An ...

  7. niushop,优秀的国产开源电商系统体验

    前几天,小编发布了国产电商开源系统推荐,有个小伙伴后台留言说niushop不错. 先别管这么多,盘他! 我这里下载的是B2C单商户免费版 先把源码下载下来.安装之前先看看niushop的环境要求. P ...

  8. cmd 查看端口占用情况

    netstat -nao|findstr 端口号 打开任务管理器查看

  9. django (三) admin后台系统

    admin后台系统 1. 安装MySQL 1,安装mysql: sudo apt install mysql-server   (安装过程中输入密码并牢记)   2,安装后进入mysql: mysql ...

  10. netty与MQ使用心得

    最近在做分布式的系统,使用netty与mq进行远程RPC调用,现将心得经验总结一下. 我们公司的服务器在云端机房,在每一个店面有一个服务器,店面服务器外网无法访问. 我们的做法是店面服务器在启动时与云 ...