Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

menambahkan hari kerja di Oracle sql

Anda dapat mencoba ini :

select max(date_field_two) as date_field_two
  from
 (
 select date'2018-08-30'+  
    cast(case when to_char(date'2018-08-30'+level,'D','NLS_DATE_LANGUAGE=ENGLISH') 
                                              in ('6','7') then 
            0
          else
            level
          end as int) as date_field_two, 
 sum(cast(case when to_char(date'2018-08-30'+level,'D','NLS_DATE_LANGUAGE=ENGLISH')  
                                               in ('6','7') then 
            0
          else
            1
          end as int)) over (order by level) as next_day
      from dual
    connect by level <= 20*1.5 
-- 20 is the day to be added, every time 5(#of business days)*1.5 > 7(#of week days)
-- 7=5+2<5+(5/2)=5*(1+1/2)=5*1.5 [where 1.5 is just a coefficient might be replaced a greater one like 2]
-- so 4*5*1.5=20*1.5 > 4*7 
  )    
 where next_day = 20;

 DATE_FIELD_TWO
-----------------
   27.09.2018

dengan menggunakan connect by dual klausa.

P.S. Mengabaikan kasus untuk hari libur umum, yang berbeda dari satu budaya ke budaya lain, tergantung pada pertanyaan yang terkait dengan hanya akhir pekan.

Demo Rextester

Sunting : Asumsikan Anda memiliki hari libur nasional pada '25-09-2018' dan '26-09-2018' (dalam rangkaian hari ini), maka pertimbangkan hal berikut:

select max(date_field_two) as date_field_two
  from
 (
 select date'2018-08-30'+  
        (case when to_char(date'2018-08-30'+level,'D','NLS_DATE_LANGUAGE=ENGLISH') 
                                              in ('6','7') then 
               0
              when date'2018-08-30'+level in (date'2018-09-25',date'2018-09-26') then
               0
              else
               level
              end) as date_field_two, 
 sum(cast(case when to_char(date'2018-08-30'+level,'D','NLS_DATE_LANGUAGE=ENGLISH')  
                                               in ('6','7') then 
                0
               when date'2018-08-30'+level in (date'2018-09-25',date'2018-09-26') then
                0 
               else
                1
               end as int)) over (order by level) as next_day
      from dual
    connect by level <= 20*2 
  )    
 where next_day = 20;

 DATE_FIELD_TWO
-----------------
   01.10.2018

yang berulang satu hari berikutnya, seperti dalam kasus ini, kecuali hari libur ini bertepatan dengan akhir pekan.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Apa tujuan dari opsi logging/nologging di Oracle?

  2. Memberikan izin kepada pengguna pada skema yang berbeda

  3. Mengekstraksi substring dari string yang diberikan

  4. Oracle10 dan JDBC:bagaimana membuat CHAR mengabaikan spasi tambahan pada perbandingan?

  5. Bagaimana cara memeriksa apakah ada prosedur tersimpan?