Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Datensätze nach Datum filtern (https://www.delphipraxis.net/173936-datensaetze-nach-datum-filtern.html)

Maya 25. Mär 2013 09:42

Datenbank: Sybase • Version: 15.7 • Zugriff über: ASE iSQL

Datensätze nach Datum filtern
 
Hallo meine Hübschen,

ich tue mich gerade mal wieder etwas schwer mit einem SQL-Statement.

Ich habe hier 'rund 500 Datensätze von Personen, die eingetragen sind mit Beginn- und Enddatum. Einige Personen sind doppelt eingetragen, wovon einer der beiden Datensätze dann ein Enddatum bekommen hat und der zweite Datensatz ein entsprechendes Beginndatum.
Hier mal ein Beispiel mit Testdaten:

Code:
ID |BEGINN    | ENDE      | NACHNAME   | VORNAME
01 |01.12.2012 |            | Schuhmacher | Michael
02 |15.04.2011 | 30.11.2012 | Schuhmacher | Michael
03 |01.12.2011 |       | Vettel     | Sebastian
04 |24.10.2011 | 30.11.2011 | Vettel     | Sebastian
05 |14.09.2011 |       | Lauda      | Niki
06 |30.06.2011 | 25.08.2011 | Lauda      | Niki
07 |05.01.2012 |       | Häkkinen   | Mika
08 |11.02.2011 | 04.01.2012 | Häkkinen   | Mika
09 |04.10.2011 |       | Barrichello | Rubens
10 |17.02.2011 | 03.10.2011 | Barrichello | Rubens
11 |01.05.2011 |       | Senna      | Ayrton
12 |07.04.2011 | 30.04.2011 | Senna      | Ayrton
13 |01.02.2011 |       | Raikönnen  | Kimi
14 |31.01.2011 | 01.02.2011 | Raikönnen  | Kimi
15 |01.07.2012 |       | Hill       | Damon
16 |24.08.2011 | 30.06.2012 | Hill       | Damon
Diese Datensätze möchte ich nun aus den Datenpool herausbekommen.

Meine bisherige Abfrage sieht wie folgt aus, aber bringt aus mir noch bisher unerfindlichen Gründen, nur vier Datensätze, obwohl es ja eindeutig mehr sein müssen.
Ach zur Info noch, in der Tabelle sind "leeren" Datenfelder während der Bearbeitung mit dem "31.12.9999" befüllt, da ich an einigen Stellen diese Spalten vergleichen muss und ich schmerzlich erfahren durfte, dass NULL nicht gleich NULL ist. ;)

Code:
SELECT *           
FROM TABELLE a, TABELLE b
WHERE a.BEGINN<>b.BEGINN
AND  a.ENDE<>b.ENDE
AND  (a.BEGINN>b.ENDE
OR    b.BEGINN>a.ENDE)
AND  a.NAME=b.NAME
AND  a.VORNAME=b.VORNAME
AND  a.ID<>b.ID
Jemand einen ultimativen Tipp, was ich übersehen habe oder wo ich vergessen habe, um die Kurve zu denken?

DeddyH 25. Mär 2013 09:55

AW: Datensätze nach Datum filtern
 
Müsste das nicht genügen?
SQL-Code:
SELECT
  *
FROM
  Tabelle A
JOIN
  Tabelle B
    ON B.Vorname = A.Vorname
    AND B.Name = A.Name
WHERE
  A.ID <> B.ID

Maya 25. Mär 2013 09:59

AW: Datensätze nach Datum filtern
 
Zitat:

Zitat von DeddyH (Beitrag 1208684)
Müsste das nicht genügen?
SQL-Code:
SELECT
  *
FROM
  Tabelle A
JOIN
  Tabelle B
    ON B.Vorname = A.Vorname
    AND B.Name = A.Name
WHERE
  A.ID <> B.ID

Nicht wirklich, weil in der Tabelle ja auch noch Datensätze drin sind, wo die Leute den gleichen Vor- und Nachnamen haben, aber die Datumsangaben (oder Datenangabe? halt die Felder mit dem Datum!) dann sich überschneiden oder in beiden Datensätze keine Angabe des Datums gibt.

DeddyH 25. Mär 2013 10:05

AW: Datensätze nach Datum filtern
 
Hmm... und so?
SQL-Code:
SELECT
  *
FROM
  Tabelle A
JOIN
  Tabelle B
    ON B.Vorname = A.Vorname
    AND B.Name = A.Name
    AND DATEDIFF(hh, A.Ende, B.Beginn) < 48
WHERE
  A.ID <> B.ID
[edit] Alternativ (vorausgesetzt, Beginn und Ende sind DATE-Felder und nicht DATETIME):
SQL-Code:
SELECT
  A.*
FROM
  Tabelle A
JOIN
  Tabelle B
    ON B.Vorname = A.Vorname
    AND B.Name = A.Name
WHERE
  DATEDIFF(dd, A.Ende, B.Beginn) = 1
OR
  DATEDIFF(dd, B.Ende, A.Beginn) = 1
[/edit]

Maya 25. Mär 2013 10:21

AW: Datensätze nach Datum filtern
 
Zitat:

Zitat von DeddyH (Beitrag 1208686)
Hmm... und so?
SQL-Code:
SELECT
  *
FROM
  Tabelle A
JOIN
  Tabelle B
    ON B.Vorname = A.Vorname
    AND B.Name = A.Name
    AND DATEDIFF(hh, A.Ende, B.Beginn) < 48
WHERE
  A.ID <> B.ID

D.h. das gibt dann doch nur die Datensätze aus, wo zwischen Ende und Beginn weniger als zwei Tage liegen, oder? Auf jeden Fall kommen jetzt nur zwei Datensätze heraus.

Es kann ja auch sein, dass zwischen dem ersten Endedatum und dem zweiten Beginndatum mehr als zwei Tage oder ein Tag liegt.

DeddyH 25. Mär 2013 10:24

AW: Datensätze nach Datum filtern
 
Und bei der Alternative (siehe mein Edit) dann wieder 4 Datensätze, richtig? Möglicherweise habe ich einfach nur nicht verstanden, welche Datensätze genau Du eigentlich haben willst.

Maya 25. Mär 2013 10:28

AW: Datensätze nach Datum filtern
 
Bei der Alternative kommt gar nichts heraus. :)

Ich möchte die oben angezeigten Datensätze herausbekommen aus einem Pool von gut 500 Datensätzen.
Voraussetzung der "doppelten" Eintragungen:
- Name, Vorname und Geb ist gleich
- ein Datensatz besitzt ein richtiges Endedatum
- Beginndatum des zweiten Datensatzes liegt NACH dem Endedatum
-> d.h. keine Überschneidungen

Es müssen sozusagen "gültige" Eintragungen sein. Man kann sich mehrfach einschreiben, aber muss sich halt vorher abgemeldet haben.

DeddyH 25. Mär 2013 10:34

AW: Datensätze nach Datum filtern
 
Nähern wir uns mal an:
SQL-Code:
SELECT
  A.*
FROM
  Tabelle A
JOIN
  Tabelle B
  ON
    A.Name = B.Name
  AND
    A.Vorname = B.Vorname
  AND
    A.Geb = B.Geb
WHERE
  B.Beginn > A.Ende
Hab ich das richtig verstanden, dass es keine Sätze mit NULL im Ende-Datum gibt, sondern dafür den 31.12.9999?

Maya 25. Mär 2013 10:36

AW: Datensätze nach Datum filtern
 
Zitat:

Zitat von DeddyH (Beitrag 1208693)
Nähern wir uns mal an:
SQL-Code:
SELECT
  A.*
FROM
  Tabelle A
JOIN
  Tabelle B
  ON
    A.Name = B.Name
  AND
    A.Vorname = B.Vorname
  AND
    A.Geb = B.Geb
WHERE
  B.Beginn > A.Ende
Hab ich das richtig verstanden, dass es keine Sätze mit NULL im Ende-Datum gibt, sondern dafür den 31.12.9999?

Korrekt und so in der Art hatte ich das ja schon und da kommen ganze vier Datensätze heraus.

CCRDude 25. Mär 2013 10:40

AW: Datensätze nach Datum filtern
 
Am Anfang schriebst Du, dass es eindeutig mehr sein müssten.
Wie eindeutig ist denn diese eindeutige Erkenntnis, bzw. aus welcher Quelle, oder kann es sein, dass Du mit falschen Annahmen arbeitest?


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:26 Uhr.
Seite 1 von 2  1 2      

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