AGB  ·  Datenschutz  ·  Impressum  







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

Datensätze nach Datum filtern

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

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 09:55
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
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
Benutzerbild von Maya
Maya

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 09:59
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.
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 10:05
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]
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

Geändert von DeddyH (25. Mär 2013 um 10:19 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Maya
Maya

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 10:21
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.
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 10:24
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.
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
Benutzerbild von Maya
Maya

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 10:28
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.
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 10:34
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?
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
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#8

AW: Datensätze nach Datum filtern

  Alt 25. Mär 2013, 11:00
Also die Vorschläge von DeddyH sind ja eigentlich ausreichend.
Und was das NULL angeht, wo nix is gibt's auch nichts zu vergleichen.
Ggf solltest Du Deine Vorgehensweise etwas ändern, z.B. Zuerst einmal die "Doppeleinträge" finden, und dann die Datenmenge solange Eingrenzen bis Du hast was Du willst.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 03:05 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