Oracle中写Procedure一直是Oracle开发中比较复杂的地方,但是掌握procedure 和cursor将使得你在Oracle开发中如鱼的水,真正体会Oracle的强大。下面通过我自己写的一个Procedure简单就procedure和cursor的使用给一个简单的讲解和示例。
一、描述问题
我要解决的问题是使用Oracle作为数据库开发一套人力资源管理系统,在这个系统中每天员工的考勤数据是通过考勤软件每天采集考勤机的数据并存成固定格式的文本文档,有相关人员通过系统上传到数据库的attendance表中。同时数据库中的employee表记录员工信息包括工卡号card_number。work_calen_emp表记录员工每天的工作日历明细也就是每天应该的上下班时间。考勤记录采集上传后需要更新Work_calen_emp表中的上下班字段的数据。
二、解决思路
这是Oracle中典型的多表查询更新问题,这个问题如何解决可以看我的Blog中另一篇转载的文章《Oracle update 多表》,其中的一个方法就是使用Cursor这个方法非常灵活,适合复杂的多表查询更新。在这个Cursor的基础上必须加上更新的日期也就是要更新哪天的考勤记录。因此我写了如下的一个procedure
三、Procedure代码
create or replace procedure proc_update_wce
--1
( v_adate8 nvarchar2 ) as
--2
cursor c(c_adate8 attendance.adate8%type) is
select e.emp_id,a.card_num,a.adate8,a.atime4,a.door,m.in_out
from employee e,attendance a,atten_machine m
where e