AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Ist sowas mit SQL machbar?
Thema durchsuchen
Ansicht
Themen-Optionen

Ist sowas mit SQL machbar?

Ein Thema von juergen · begonnen am 3. Mär 2016 · letzter Beitrag vom 5. Mär 2016
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
1.174 Beiträge
 
Delphi 11 Alexandria
 
#1

Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 16:45
Datenbank: Pervasive • Version: 10 • Zugriff über: PDAC
Hallo zusammen,

ich habe eine Tabelle wo Abwesenheiten drin stehen. Pro Tag ein Datensatz.

Jetzt benötige ich folgende Ausgabe:

PersNr xBeginn-DatumUhrzeit xEnde-DatumUhrzeit xFehlart x
000000011602.06.201600:00:0005.06.201624:00:00Urlaub
000000011704.06.201600:00:0014.06.201624:00:00Urlaub

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!
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
4dk2

Registriert seit: 4. Sep 2007
176 Beiträge
 
#2

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 16:52
hmm,
Möglichkeit A wäre wenn die Datenbank unterstützt ne Stored Procedure
Möglichkeit B wären Subquerys, je nachdem welche Datenbank

EDIT:
Streichen:
Um welche Datenbank geht es ?

War zu schnell XD
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#3

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 16:53
Pervasive, steht oben im Eingangspost
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
4dk2

Registriert seit: 4. Sep 2007
176 Beiträge
 
#4

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 16:57
Pervasive, steht oben im Eingangspost
ja ich habs nachher gesehen... das Brett vorm Kopf hatte es verdeckt
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#5

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 17:09
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.
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#6

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 17:23
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.
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.016 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#7

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 17:27
Das hier sieht aus, als ob es für dich hilfreich sein könnte, ob das mit deiner DB geht, musst du selbst schauen: http://www.sqlservercentral.com/articles/T-SQL/71550/
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.034 Beiträge
 
Delphi 12 Athens
 
#8

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 18:14
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?
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#9

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 19:16
Ich wüßte jetzt nicht ob
a) das überhaupt möglich ist und
b) wie man das lösen könnte
Ich versteh glaub ich das Problem nicht ganz. Du kannst das so machen, die Tabelle wird es Dir nicht übel nehmen.

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.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
1.174 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: Ist sowas mit SQL machbar?

  Alt 3. Mär 2016, 20:00
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!
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:21 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz