CREATE OR REPLACE FUNCTION check_continuous_days(input_table IN VARCHAR2, input_date_field IN VARCHAR2) RETURN NUMBER IS date_array DBMS_UTILITY.uncl_array; day_diff NUMBER; continuous_day NUMBER := 1; BEGIN -- 查询指定表中的日期数据,并按照日期升序排序 SELECT to_char(cday,'yyyymmdd') BULK COLLECT INTO date_array FROM HR_ABSENCE ORDER BY cday ASC; -- 按照日期顺序比较相邻两个日期之间的天数差 FOR i IN 2..date_array.count LOOP day_diff := date_array(i) - date_array(i-1); IF day_diff = 1 THEN continuous_day := continuous_day + 1; ELSE continuous_day := 1; END IF; END LOOP; -- 返回连续的天数 RETURN continuous_day; END; 需要返回每个人的开始连续和结束时间以及每个人的连续天数 怎么改
时间: 2024-02-14 21:14:47 浏览: 155
CreateTable.rar_create table ja_createTab_createTable
你的代码中只考虑了一个表中的连续天数,并且返回的值只是总的连续天数。如果你需要返回每个人的开始连续和结束时间以及每个人的连续天数,那么你需要对代码进行一些修改。以下是修改后的代码示例:
```
CREATE OR REPLACE TYPE continuous_days_type AS OBJECT (
person_id NUMBER,
start_date DATE,
end_date DATE,
continuous_days NUMBER
);
/
CREATE OR REPLACE TYPE continuous_days_table_type AS TABLE OF continuous_days_type;
/
CREATE OR REPLACE FUNCTION check_continuous_days RETURN continuous_days_table_type IS
date_array DBMS_UTILITY.uncl_array;
person_id NUMBER;
start_date DATE;
end_date DATE;
day_diff NUMBER;
continuous_days NUMBER := 1;
continuous_days_table continuous_days_table_type := continuous_days_table_type();
BEGIN
-- 查询指定表中的日期数据,并按照人员和日期升序排序
SELECT person_id, cday
BULK COLLECT INTO date_array
FROM HR_ABSENCE
ORDER BY person_id ASC, cday ASC;
-- 按照人员和日期顺序比较相邻两个日期之间的天数差
FOR i IN 2..date_array.count LOOP
IF date_array(i-1).person_id <> date_array(i).person_id THEN
-- 如果遇到新的人员,将前一个人员的信息添加到返回结果中
continuous_days_table.extend;
continuous_days_table(continuous_days_table.last) := continuous_days_type(
person_id => person_id,
start_date => start_date,
end_date => end_date,
continuous_days => continuous_days
);
-- 重置连续天数和起始日期
continuous_days := 1;
start_date := date_array(i).cday;
ELSE
-- 如果是同一个人员,比较相邻两个日期之间的天数差
day_diff := date_array(i).cday - date_array(i-1).cday;
IF day_diff = 1 THEN
continuous_days := continuous_days + 1;
end_date := date_array(i).cday;
ELSE
-- 如果不连续,将前一个人员的信息添加到返回结果中
continuous_days_table.extend;
continuous_days_table(continuous_days_table.last) := continuous_days_type(
person_id => person_id,
start_date => start_date,
end_date => end_date,
continuous_days => continuous_days
);
-- 重置连续天数和起始日期
continuous_days := 1;
start_date := date_array(i).cday;
END IF;
END IF;
-- 记录当前人员编号
person_id := date_array(i).person_id;
END LOOP;
-- 添加最后一个人员的信息到返回结果中
continuous_days_table.extend;
continuous_days_table(continuous_days_table.last) := continuous_days_type(
person_id => person_id,
start_date => start_date,
end_date => end_date,
continuous_days => continuous_days
);
-- 返回结果
RETURN continuous_days_table;
END;
/
```
这个函数返回一个自定义类型 `continuous_days_type` 的数组,每个元素表示一个人员的连续天数信息,包括人员编号、开始连续时间、结束连续时间和连续天数。你可以根据需要对返回结果进行展示或者其他操作。
阅读全文