注文の納期を示す MS Access クエリがあります。2 つの問題:
- 時間は 24 時間制 (例: 0105) であるため、CPOE 時間から検証時間を差し引くと、分でも時間でもない値が得られるため、単純に分に変換することはできません (つまり、 : 0701 – 0527 = 174、実際の差は 94 分)、
- CPOE 時刻が午前 0 時より前で、検証時刻が午前 0 時より後の場合、差は非常に歪んでいます (つまり、2351 – 0024 = 2327、実際の差は 33 分です)。
誰でもこれを解決する方法を知っていますか? SQL クエリは次のとおりです。
SELECT
BI.PTNAME,
PHM_POE_HIST.FUNCTION,
PHM_ORDERS.VALIDATED_DATE,
PHM_ORDERS.VALIDATED_BY,
SAT.USER_NAME,
PHM_ORDERS.VALIDATED_TIME,
Right([TRAN_DATE_TIME],4) AS CPOE_TIME,
Abs([validated_time]-[CPOE_TIME]) AS Diff,
PHM_POE_HIST.TRAN_DATE_TIME,
PHM_POE_HIST.EFF_DATE_TIME,
PHM_POE_HIST.HIST_SEQ, BI.NRS_STATION,
SITE.NAME, PHM_ORDERS.PMP,
PHM_ORDERS.PRIORITY,
Trim([GENERIC_NAME] & " " & [STRENGTH] & " " & [STRENGTH_UNIT] & " " & [DOSAGE_FORM] & " " & [LATIN_DIR_ABBR]) AS DESCRIPTION
FROM
((BI LEFT JOIN
(PHM_ORDERS LEFT JOIN PHM_POE_HIST ON (PHM_ORDERS.POE_ORDER_NUMBER = PHM_POE_HIST.POE_ORDER_NUMBER) AND (PHM_ORDERS.ITN = PHM_POE_HIST.ITN))
ON BI.ITN = PHM_ORDERS.ITN)
LEFT JOIN SAT
ON PHM_ORDERS.VALIDATED_BY = SAT.USER_INITIALS)
LEFT JOIN SITE
ON BI.SITE = SITE.SITE
WHERE
(((BI.PTNAME) Is Not Null)
AND ((PHM_POE_HIST.FUNCTION)="NW")
AND ((PHM_ORDERS.VALIDATED_DATE)=datereltoday(-1))
AND ((PHM_ORDERS.PRIORITY)="STAT"));