AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken 3-fache Zeitüberschneidung
Thema durchsuchen
Ansicht
Themen-Optionen

3-fache Zeitüberschneidung

Ein Thema von aberglan · begonnen am 2. Sep 2013 · letzter Beitrag vom 2. Sep 2013
Antwort Antwort
Benutzerbild von Valle
Valle

Registriert seit: 26. Dez 2005
Ort: Karlsruhe
1.223 Beiträge
 
#1

AW: 3-fache Zeitüberschneidung

  Alt 2. Sep 2013, 16:28
Hi,

ich hab das jetzt nicht getestet, weil das Anlegen der Demodaten mir zu lange dauern würde, aber kannst du das nicht einfach so machen?

Code:
SELECT * FROM a
WHERE EXISTS(SELECT id FROM b WHERE b.start BETWEEN a.start AND a.end)
OR EXISTS(SELECT id FROM c WHERE c.start BETWEEN a.start AND a.end)
Wenn du das per-Mitarbeiter machen willst, kannst du die beiden Subqueries sicherlich um ein "AND a.mitarbeiterID = b|c.mitarbeiterID" erweitern.

Interessant wäre noch, wie groß die Tabelle so ist oder werden kann. Es gibt sicherlich noch performantere Lösungen, die ohne 2 Subqueries auskommen.

Was deine vielen IFs da machen versteh ich auch nicht so recht.

Edit:// Weitere Möglichkeit, ohne Subquery, daher vermutlich schneller:

Code:
SELECT a.* FROM a, b, c
WHERE b.start BETWEEN a.start AND a.end
OR c.start BETWEEN a.start AND a.end
Hab's mit 3 einfachen Tabellen und insgesamt 4 Einträgen auch mal getestet.

Liebe Grüße,
Valentin
Valentin Voigt
BOFH excuse #423: „It's not RFC-822 compliant.“
Mein total langweiliger Blog

Geändert von Valle ( 2. Sep 2013 um 16:33 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: 3-fache Zeitüberschneidung

  Alt 2. Sep 2013, 16:39
Und was ist, wenn ein Termin vorher beginnt, aber innerhalb des anderen endet? Oder einer einen anderen vollständig überlappt, also vorher beginnt und nachher endet?
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
 
#3

AW: 3-fache Zeitüberschneidung

  Alt 2. Sep 2013, 16:54
Ich denke das kann man schon mit dem
Code:
WHERE b.start BETWEEN a.start AND a.end
erschlagen.
Nur muß B immer aus allen 3 Tabellen gefüttert werden.
(wer ist eigentlich auf diese "Schnapsidee" mit den 3 Tabellen gekommen?)

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

Registriert seit: 26. Dez 2005
Ort: Karlsruhe
1.223 Beiträge
 
#4

AW: 3-fache Zeitüberschneidung

  Alt 2. Sep 2013, 17:11
Und was ist, wenn ein Termin vorher beginnt, aber innerhalb des anderen endet? Oder einer einen anderen vollständig überlappt, also vorher beginnt und nachher endet?
Stimmt, die fehlen.

Wenn wir zwei Intervalle A und B haben, dann schneiden sie sich aber doch immer, wenn entweder A.start in B oder B.start in A, oder? Fehlt noch was?

Mikkey hat schon eine schöne gepostet, finde ich. Dass er direkt die entsprechenden Mitarbeiter selektiert finde ich auch schöner, als willkürlich Tabelle A zu verwenden.

Liebe Grüße,
Valentin
Valentin Voigt
BOFH excuse #423: „It's not RFC-822 compliant.“
Mein total langweiliger Blog
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#5

AW: 3-fache Zeitüberschneidung

  Alt 2. Sep 2013, 18:48
Wenn ich mal wieder unterschiedliche Tabellen vor mir habe (was sehr häufig vorkommt, man sollte die Entwickler echt peitschen, die so einen Dreck verzapfen), die man aber eigentlich über einen Kamm scheren muss, mache ich in etwa Folgendes:

Code:
select 'Tabelle' as Tabelle, Feld1, Feld2 ... from Tabelle
union
select 'AndereTabelle' as Tabelle, FeldX, FeldY ... from AndereTabelle
...
Das ganze am Besten hinter einer View. Ich unifiziere also meine heterogenen Daten, um anschließend bequem mit ihnen arbeiten zu können. Die Spalte 'Tabelle' habe ich, um hinterher zu wissen, wo das Zeugs herkommt.

Mit dieser View kann ich dann so arbeiten, also ob die DB nicht versaut wäre. Is nur lahm (kann man aber manchmal verbessern, Stichwort materialized view).
  Mit Zitat antworten Zitat
Antwort Antwort


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