![]() |
Datenbank: Pervasive • Version: 10 • Zugriff über: PDAC
Ist sowas mit SQL machbar?
Hallo zusammen,
ich habe eine Tabelle wo Abwesenheiten drin stehen. Pro Tag ein Datensatz. Jetzt benötige ich folgende Ausgabe:
Die Felder mit dem x habe ich. Der Knackpunkt sind das Beginn-Datum und das Ende-Datum! Es gibt in der Tabelle ja pro Tag einen Datensatz. Ich wüßte jetzt nicht ob a) das überhaupt möglich ist und b) wie man das lösen könnte Für eure Hilfe bedanke ich mich schon mal vorab! |
AW: Ist sowas mit SQL machbar?
hmm,
Möglichkeit A wäre wenn die Datenbank unterstützt ne Stored Procedure :-D Möglichkeit B wären Subquerys, je nachdem welche Datenbank :) EDIT: Streichen: Um welche Datenbank geht es ? :lol: War zu schnell XD |
AW: Ist sowas mit SQL machbar?
Pervasive, steht oben im Eingangspost ;)
|
AW: Ist sowas mit SQL machbar?
Zitat:
|
AW: Ist sowas mit SQL machbar?
Das einfachste wäre wahrscheinlich wie schon genannt eine Stored Procedure.
Da kannst du dann alle Datensätze selektieren, entsprechend nach Personalnummer und Datum sortieren und jedes mal wenn sich die Art der Abwesenheit oder die Personalnummer ändert, oder wenn der Aktuelle Tag > LetzterTag + 1 erzeugst du einen Datensatz. |
AW: Ist sowas mit SQL machbar?
Ich behaupte einfach mal, dass das auch nur mit SQL geht, aber wahrsch. kompliziert.
Idee: Left Join der Tabelle auf sich selber, Bedingung PNR=PNR und Datum=Datum-1 Weiterer Left Join der Tabelle auf sich selber, Bedingung PNR=PNR und Datum=Datum+1 Die Datumse wo einer der Joins null ist ist Begin oder Ende eines Fehlzeitraumes. Die Datumse wo keiner der Joins null ist inmitten eines Fehlzeitraumes. Wird nicht weiter beachtet. Die Datumse wo beide Joins null sind, sind 1-tägige Fehlzeiten. Darüber ein weiterer Select der (bei mehrtägigen FZ) einem Begin-Fehlzeit-Datum das nächst kleinere Ende-Fehlzeit-Datum zuordnet. |
AW: Ist sowas mit SQL machbar?
Das hier sieht aus, als ob es für dich hilfreich sein könnte, ob das mit deiner DB geht, musst du selbst schauen:
![]() |
AW: Ist sowas mit SQL machbar?
Kann man nicht über 'ne WindowFunction, oder so, den aufeinanderfolgenden zusammengehörigen Datensätzen eine gleiche ID vergeben (wenn davor die gleiche Fehlart, dann gibt mir die selbe ID)
und das zusammengehörige dann per GROUP BY und paar AggregateFunctions zusammenfassen? |
AW: Ist sowas mit SQL machbar?
Zitat:
Aber was soll dadurch erreicht werden? Werden die "täglichen" Datensätze so generiert? Ist das eine Erweiterung die tägliche DS sparen soll? Ich vermute, es geht darum für 10 Tage Urlaub 9 Datensätze zu sparen oder? Fakt ist, die Spalten mit Beginn / Ende zusammen mit der Vorgabe ergeben redundante Daten. Das ist nicht gut gemäß Vorschrift und Erfahrung. |
AW: Ist sowas mit SQL machbar?
Hallo zusammen,
erst einmal Danke für die ganzen Antworten! @jobo, Die DB (bzw. Tabelle) ist so gegeben, da kann nichts angepasst werden. Der Kunde erwartet als Ergebnis nicht die einzelnen Tages-Datensätze sondern das Ganze zusammengefasst in einer Zeile, wenn es der gleiche Fehlgrund ist. Als Ergebnis soll eine csv-Datei "rauskommen" die der Kunde in einem anderen System wieder importiert. Ich werde das Ganze nun mit Delphi lösen. Das scheint erst mal relativ einfach, wenn die Datenmenge nach PersNr und Datum sortiert ist. Allen ein erholsamer Feierabend! :dp: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:22 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-2025 by Thomas Breitkreuz