AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Datensätze nach Datum filtern
Thema durchsuchen
Ansicht
Themen-Optionen

Datensätze nach Datum filtern

Ein Thema von Maya · begonnen am 25. Mär 2013 · letzter Beitrag vom 25. Mär 2013
 
Benutzerbild von Maya
Maya

Registriert seit: 15. Jun 2011
Ort: Potsdam-Mittelmark
107 Beiträge
 
Delphi 2010 Enterprise
 
#1

Datensätze nach Datum filtern

  Alt 25. Mär 2013, 09:42
Datenbank: Sybase • Version: 15.7 • Zugriff über: ASE iSQL
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?
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
 


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 23:54 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