„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie berechnet man die Geschäftszeiten zwischen zwei Daten in Oracle SQL?

Wie berechnet man die Geschäftszeiten zwischen zwei Daten in Oracle SQL?

Gepostet am 2025-02-06
Durchsuche:263

How to Calculate Business Hours Between Two Dates in Oracle SQL?

stunden basierend auf den Geschäftszeiten in oracle sql

In Oracle SQL können Stunden zwischen zwei Zeiträumen berechnet werden. Wenn Sie jedoch die Geschäftszeiten berücksichtigen müssen, wird die Berechnung komplexer.

Geschäftszeitenspezifikation

Die bereitgestellten Geschäftszeiten sind Montag bis Samstag von 8:00 Uhr Bin bis 18.00 Uhr. Um diese Stunden in die Berechnung einzubeziehen, können Sie eine Kombination aus Manipulation und bedingter Logik verwenden.

sql query

Die folgende SQL -Abfrage liefert eine Lösung für die Berechnung der Stunden Basierend auf den angegebenen Geschäftszeiten:

SELECT task,
       start_time,
       end_time,
       ROUND(
         (
           -- Calculate the full weeks difference from the start of ISO weeks.
           ( TRUNC( end_time, 'IW' ) - TRUNC( start_time, 'IW' ) ) * (10/24) * (6/7)
           -- Add the full days for the final week.
             LEAST( TRUNC( end_time ) - TRUNC( end_time, 'IW' ), 6 ) * (10/24)
           -- Subtract the full days from the days of the week before the start date.
           - LEAST( TRUNC( start_time ) - TRUNC( start_time, 'IW' ), 6 ) * (10/24)
           -- Add the hours of the final day
             LEAST( GREATEST( end_time - TRUNC( end_time ) - 8/24, 0 ), 10/24 )
           -- Subtract the hours of the day before the range starts.
           - LEAST( GREATEST( start_time - TRUNC( start_time ) - 8/24, 0 ), 10/24 )
         )
         -- Multiply to give minutes rather than fractions of full days.
         * 24,
         15 -- Number of decimal places
       ) AS work_day_hours_diff
FROM   your_table;

Erklärung

  • weeks: Die Abfrage berechnet zuerst die vollen Wochen innerhalb des Bereichs mit TRUNC (end_time, 'iw ') und Trunc (start_time,' iw '). Diese Berechnungen geben die Start- und Enddaten der ISO -Wochen mit Start und Ende der Aufgabe. Tage am Anfang und am Ende des Bereichs, in dem die Geschäftszeiten möglicherweise nicht gelten.
  • Stunden: Der Unterschied in den Stunden für den letzten Tag und den Tag vor dem Start des Sortiments werden ähnlich berechnet.
  • multiplication: Die endgültige Berechnung multipliziert das Ergebnis um 24, um Minuten in Stunden umzuwandeln.
  • Beispieldaten und Ausgabe

mit den bereitgestellten Beispieldaten: Aufgabe | Start_time | End_time A | 16-Jan-17 10:00 | 23-Jan-17 11:35 B | 18-Jan-17 17:53 | 19-Jan-17 08:00 C | 13-Jan-17 13:00 | 17-Jan-17 14:52 D | 21-Jan-17 10:00 | 30-Jan-17 08:52

Die Abfrage gibt die folgenden Ergebnisse aus:

TASK | START_TIME | END_TIME
A | 16-JAN-17 10:00 | 23-JAN-17 11:35
B | 18-JAN-17 17:53 | 19-JAN-17 08:00
C | 13-JAN-17 13:00 | 17-JAN-17 14:52
D | 21-JAN-17 10:00 | 30-JAN-17 08:52

task starten_time a 2017-01-16 10:00:00 (mon) b 31.8666666666667 2017-01-21 10:00:00 (SAT)
] End_time work_day_hours_diff
2017-01-23 11:35:00 (mon) 61.58333333333333
2017-01-18 17:53: 00 (mi) 2017-01-19 08:00:00 (thu) . 2017-01-13 13:00:00 (Fri) 2017-01-17 14:52:00 (tue)
D
2017-01-30 08:52:00 (mon)

68.8666666666667

How to Calculate Business Hours Between Two Dates in Oracle SQL?

Diese Ergebnisse spiegeln genau die Anzahl der Arbeitszeiten auf der Grundlage der angegebenen Geschäftszeiten wider.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3