![]() |
Datenbank: ADS • Version: 10 • Zugriff über: Lua
Dauer einer Tätigkeit zwischen einer Zeitspanne
Guten Morgen,
ich benötige ein SQL Statement, dass mir die Dauer einer Tätigkeit zwischen einer Zeitspanne zurückgibt. Die Dauer der "kompletten" Tätigkeit habe ich bereits in einem SQL Statement ausgelesen. (arbeitet tagesübergreifend) Jetzt möchte ich aber noch wissen, wie lang er die Tätigkeit zum Beispiel im Zeitraum von 22 Uhr bis 5 Uhr morgens ausgeübt hat.
Code:
Hoffe mir kann jemand weiterhelfen.
SELECT TIMESTAMPDIFF(SQL_TSI_MINUTE, MIN(CONVERT(CONVERT(Datum + IFNULL(Me1Day, 0),
SQL_CHAR) + ' ' + CONVERT(Bewertet1, SQL_CHAR), SQL_TIMESTAMP)), MAX(CONVERT(CONVERT(Datum + IFNULL(Me2Day, 0), SQL_CHAR) + ' ' + CONVERT(Bewertet2, SQL_CHAR), SQL_TIMESTAMP))) FROM Buchungen WHERE Datum = '11.04.2012' and ID_Personal = 152 and TaetigkNr= '25' MfG |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
also mich würde die Struktur Deiner DB schon interessieren.
Bis jetzt habe ich mitbekommen, daß dort ein Datum ein Timestamp,ID_Personal und ein Tätigkeitsschlüssel existiert. Um zu wissen ob eine Tätigkeit in einem Zeitraum betrieben wurde benötige ich im allgemeinen Start- und End-Zeit. Gruß K-H |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Zitat:
Den Timestamp den setz ich mir selbst in meinem SQL zusammen, um eben dann die Differenz von zwei Timestamps zu errechnen. Ein Timestamp ist nicht in der Tabelle vorhanden. |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Vielleicht wird es anhand von Beispielen deutlicher was ich erreichen möchte.
1. --Festgelegter Zeitraum = 22 Uhr bis 05 Uhr-- Mitarbeiter arbeitet von 22 Uhr bis 01 Uhr --> Ergebnis: 3 h 2. --Festgelegter Zeitraum = 22 Uhr bis 05 Uhr-- Mitarbeiter arbeitet von 21 Uhr bis 22:30 Uhr --> Ergebnis: 0,5 h und ich weiß einfach nicht wie ich das herausfinden kann ? :( |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Kennt ADS DateDiff?
|
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
|
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Ich kenne ADS nicht, etwas in der Art ?
Delphi-Quellcode:
die Datumszeitwerte hast Du ja schon ?
Select Round(dateDiff(n,Getdate(),GetDate() + '00:45:00') / 60.0 , 2)
|
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Zitat:
Berechnet wird hier doch die Differenz der zwei Datumswerte wobei auf den zweiten noch 45 Minuten addiert werden und wann wieder durch 60 geteilt wird und gerundet werden soll auf 2 stellen nach dem komma ... Aber wird hierbei die dauer einer tätigkeit zwischen einem zeitraum berücksichtigt? |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Getdate() und GetDate() + '00:45:00' stehen für Deine Zeitfelder zuzüglich korrigiertem Datum,
ich Frage in Minuten ab um Stundenbruchteile liefern zu können (sonst bekommst Du bei 45 min > 0) und Runde es auf eine von Dir anzupasssende Art |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Guten morgen.
Also die Funktion DateDiff gibts in der Sybase DB doch nicht ... habs jetzte über nen komplett andren weg gelöst (software) aber häte da noch eine frage .. ein Mitarbeiter hat mehrere buchungen: Datum Kommen Gehen 10.04.2012 11.04.2012 03:00:00 10.04.2012 06:00:00 10.04.2012 10.04.2012 22:00:00 10.04.2012 23:00:00 10.04.2012 10.04.2012 23:00:00 10.04.2012 03:00:00 10.04.2012 11.04.2012 02:00:00 10.04.2012 03:00:00 ich möchte mir jetzt die erste Kommen buchung auslesen und die letzte Gehen Buchung mit:
Code:
er liefert mir aber das falsche ...
SELECT Datum,
MIN(CONVERT(CONVERT(b.Datum + IFNULL(b.Me1Day, 0), SQL_CHAR) + ' ' + CONVERT(b.Me1, SQL_CHAR), SQL_TIMESTAMP)) as Kommen, MAX(CONVERT(CONVERT(b.Datum + IIF(LEFT(CONVERT(b.Me2, SQL_CHAR), 5) = '00:00', 1, 0), SQL_CHAR) + ' ' + CONVERT(b.Me2, SQL_CHAR), SQL_TIMESTAMP)) as Gehen FROM Buchungen WHERE ID_Personal = 152 and Datum = '10.04.2012' GROUP BY 1
Code:
hat jemand ne erklärung dafür?
Datum Kommen Gehen
10.04.2012 10.04.2012 22:00:00 10.04.2012 23:00:00 |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Das Ergebnis der SQL-Abfrage ist auf Grund der gegebenen Daten richtig.
Nur scheinen mir die Daten ein wenig unsinnig. Wie kann jemand schon gehen, bevor er angekommen ist. |
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Zitat:
|
AW: Dauer einer Tätigkeit zwischen einer Zeitspanne
Zitat:
Gruß K-H |
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:12 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz