Показать вакансии старше 3 рабочих дней - PullRequest
0 голосов
/ 17 февраля 2020

Может ли кто-нибудь предложить какую-либо помощь в том, как бы я изменил код SQL, чтобы показать работы, которые старше 3 рабочих дней?

У меня есть следующий код:

select
central_enquiry.enquiry_number,
central_enquiry.enquiry_time,
central_enquiry.officer_code,
type_of_service.service_code,
type_of_service.service_name,
enquiry_subject. subject_code,
enquiry_subject.subject_name,
central_site.site_name,
central_enquiry.enquiry_address,
central_enquiry.enquiry_desc,
enquiry_status.enq_status_code,
enquiry_status.enq_status_name,
central_enquiry.log_effective_date,
central_enquiry.follow_up_date,

CASE
when round((SYSDATE - central_enquiry.enquiry_time),2) >=3 then 'Over 3 days'
else ''
end as Days_since_reported


from
central_enquiry
inner join enquiry_subject on enquiry_subject.subject_code = central_enquiry.subject_code
inner join type_of_service on type_of_service.service_code = enquiry_subject.service_code
inner join enquiry_status_log on central_enquiry.enquiry_number = enquiry_status_log.enquiry_number and central_enquiry.enquiry_log_number = enquiry_status_log.enquiry_log_number
inner join enquiry_status on enquiry_status.enq_status_code = enquiry_status_log.enq_status_code
inner join central_site on central_site.site_code = central_enquiry.site_code


where
type_of_service.service_code = 'ECPE' and
round((SYSDATE - central_enquiry.enquiry_time),2) >=3 and
central_enquiry.officer_code = 'BSO' and
central_enquiry.outstanding_flag = 'Y'


order by central_enquiry.enquiry_number

Это показывает мне все задания, которые были зарегистрированы более 3 дней go на основе текущей даты.

where  round((SYSDATE - central_enquiry.enquiry_time),2) >=3 

Однако я хочу, чтобы это показывало только те работы, которые были зарегистрированы более 3 BUSINESS дни a go - поэтому, если задание было зарегистрировано в четверг 13 февраля - оно будет отображаться в отчете, только если оно прошло после того же времени во вторник 18 февраля.

1 Ответ

1 голос
/ 17 февраля 2020

Вы должны манипулировать своим состоянием следующим образом:

where round((SYSDATE - central_enquiry.enquiry_time),2) 
- case when to_char(SYSDATE,'dy') in ('mon','tue') then 2 else 0 end >=3

Ура !!

...