目的和到目前为止我所拥有的
我正在尝试创建一个视图来检查丢失的劳动力交易。该视图将提供给 Crystal 报表。
在这种情况下,视图应采用 sysdate+30 和 sysdate -30 之间的所有日期,然后应将所有这些日期的在职员工的所有劳动记录留在外部联接。然后,它会计算每个员工在每个日期的劳务交易次数。
这将传递给 Crystal Report,它将根据特定的日期范围(在视图的 +/- 30 范围内)进行过滤。从那里开始,Crystal 中每个员工的所有天数将汇总,员工将显示哪些交易为零。
问题
在没有吐出每个日期的列表的情况下,最初,我在每个日期都使用人工交易,但有些人对任何日期都没有计数。这些人显示零小时的空交易日期。这表明他们在整个期间不收费,这是有道理的。
但是,当 Crystal 对该数据进行过滤并选择一个范围时,我相信它会忽略这些空值,因此不允许我展示所有没有时间提交的人。
问题
有没有办法在视图中执行相当于“选择 (sysdate+30) 和 (sysdate-30) 之间的每个日期”的方法,以便我可以一直使用它来比较?
SQL(供参考)
SELECT QUERY.LABORRECLABORCODE
, QUERY.LABORRECEMPLOYEENUM
, QUERY.PERSONRECDISPLAYNAME
, QUERY.TRANSSTARTDATE
, COUNT(TRANSROWSTAMP) AS ROWCOUNT
FROM (SELECT *
FROM (SELECT LABOR.LABORCODE AS LABORRECLABORCODE
, LABOR.LA20 AS LABORRECEMPLOYEENUM
, PERSON.DISPLAYNAME AS PERSONRECDISPLAYNAME
FROM LABOR
LEFT OUTER JOIN PERSON
ON ( LABOR.LABORCODE = PERSON.PERSONID )
WHERE LABOR.STATUS = 'ACTIVE'
AND LABOR.LA20 IS NOT NULL
AND PERSON.DISPLAYNAME IS NOT NULL
AND LOWER(PERSON.DISPLAYNAME) NOT LIKE '%kimball%'
AND LOWER(PERSON.DISPLAYNAME) NOT LIKE '%electrico%'
AND LOWER(PERSON.DISPLAYNAME) NOT LIKE '%misc labor cost adj%'
AND LOWER(PERSON.DISPLAYNAME) NOT LIKE '%brossoit%'
AND LOWER(PERSON.DISPLAYNAME) NOT LIKE '%brossiot%')PERSONINFO
LEFT OUTER JOIN (SELECT STARTDATE AS TRANSSTARTDATE
, LABORCODE AS TRANSLABORCODE
, ROWSTAMP AS TRANSROWSTAMP
FROM LABTRANS
WHERE STARTDATE BETWEEN ( SYSDATE - 30 ) AND ( SYSDATE + 30 ))LABTRANSLIMITED
ON ( PERSONINFO.LABORRECLABORCODE = LABTRANSLIMITED.TRANSLABORCODE ))QUERY
GROUP BY LABORRECLABORCODE
, TRANSSTARTDATE
, LABORRECEMPLOYEENUM
, PERSONRECDISPLAYNAME
ORDER BY LABORRECLABORCODE
, TRANSSTARTDATE
;