实训7 PL_SQL程序设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实训7 PL_SQL程序设计

实训7 PL/SQL程序设计 目标 完成本实验后,将掌握以下内容: () () (3)过程和函数的创建 (4)触发器的创建 (5)异常处理 准备工作 建立实训环境。 在进行本实训前,必须先建立实训用环境。请先通过执行练习前创建实训环境的脚本(实训\Ch9\实训练习\建立实训环境.sql)创建相应实训环境。 场景 东升软件公司的人事管理系统数据库,在系统日常运行过程中,员工为了安全原因,可能需要修改自身的登录密码,为了方便应用程序开发人员的开发工作,同时提高系统安全性,需要创建相应的过程,以完成修改登录密码的工作。为实现员工的请假功能,同时简化应用程序的开发,对员工修改其未批准的申请和部门负责人对申请的处理,都需要处理更新员工请假申请记录。由于公司对于员工的请假需要员工所在部门的部门经理批准,在员工提交请假申请时,员工的请假时间已经变更到数据库中,当部门经理对请假申请否决后,需要把这部分的时间再还原到减少前的状态。为了方便应用程序的开发,减少代码的复杂性,通过触发器完成请假时间的还原功能。 实验预估时间:180分钟 练习1 创建过程 本练习中,将创建存储过程,创建的存储过程将完成修改员工登录密码的功能,在更新登录密码时,必须提供对应员工的登录名、原登录密码以及新的登录密码。在存储过程中,将对数据库中当前数据进行查询,以确定对应员工的登录名和登录用密码是否正确,如果有以应的员工存在,则把对应员工的登录密码修改为新的指定的密码。本存储过程创建完成后,在应用程序开发过程中,可直接调用存储过程完成员工密码的修改,简化了应用程序开发的难度,同时提高了数据库安全性。 实验步骤: () () /****** 对象: 存储过程 sp_ChangePassword ******/ CREATE OR REPLACE PROCEDURE sp_ChangePassword ( vloginName VARCHAR2, voldPassword VARCHAR2, vnewPassword VARCHAR2 ) AS empID NUMBER; BEGIN select EmployeeID INTO empID from Employee where ELoginName = vloginName and EPassword = voldPassword; IF (empID 0 AND NOT (empID IS NULL)) THEN Update Employee set EPassword = vnewPassword where EmployeeID = empID; END IF; EXCEPTION WHEN PROGRAM_ERROR THEN NULL; WHEN OTHERS THEN NULL; END sp_ChangePassword; / 练习2 创建函数 当员工提交完请假申请后,员工可以修改其申请内容,同时,申请需要员工所在部分负责人处理申请。对请假申请的处理可以批准相关的申请,也可以否决请假申请。为实现此功能,创建对应的函数,返回被影响的行数,如果没有数据行被更新,或发生异常,返回-1。 实验步骤: () 图9.1 Oracle SQL Developer () /****** 对象: 函数 sp_ChangeLeaveStatus ******/ CREATE OR REPLACE FUNCTION sp_ChangeLeaveStatus ( vLeaveID NUMBER, vStatus VARCHAR2, vDenyReason VARCHAR2 := ) RETURN NUMBER AS vhours NUMBER; BEGIN update Leave set Status = VStatus, DenyReason = VDenyReason where LeaveID = VLeaveID; SELECT hours INTO vhours FROM Leave WHERE (Leave.LeaveID = vLeaveID); IF vStatus = 已否决 THEN update Employee set EVacationRemain = EVacationRemain + vhours; END IF; RETURN SQL%ROWCOUNT; EXCEPTION WHEN PROGRAM_ERROR THEN RETURN -1; WHEN

文档评论(0)

xy88118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档