diskskin
Goto Top

Zeitraum - Aktuelles Datum weniger 30 Tage - via MS SQL berechnen

Hallo zusammen,

es existieren zwar einige Beiträge, die sich mit diesem Thema beschäftigen, dennoch
habe ich nichts gefunden, was eindeutig passen würde. Deshalb meine Frage:

Wie berechne ich in einer WHERE-Bedingung unter MS SQL 2005 einen Zeitraum vom aktuellen
Datum und 30 Tage zurück. Also z.B. von Heute (24.11.2008) bis zum 24.10.2008? Die Datenbank
soll alle Datensätze zurückliefern, die in diesem Zeitraum liegen.

Danke im voraus!
Beste Grüße
ds

Content-Key: 102543

Url: https://administrator.de/contentid/102543

Ausgedruckt am: 29.03.2024 um 05:03 Uhr

Mitglied: Biber
Biber 24.11.2008 um 16:54:09 Uhr
Goto Top
Moin diskskin,

dafür ist die DateDiff()-Funktion gedacht. Hier jetzt mal als SQL bzw. T-SQLSkalarfunktion, nicht als VB/VBSkript-Implementierung.

Beispiel:

SELECT * From DyTable 
Where DATEDIFF(day,  DyTable.DyTimestamp, CURRENT_TIMESTAMP) <= 30;

Geht natürlich nicht nur mit Timestamp-Datumsfeldern, sonder auch mit date/datetime.

Grüße
Biber
Mitglied: diskskin
diskskin 25.11.2008 um 10:54:37 Uhr
Goto Top
Moin Biber,

Danke für die schnelle Antwort. Klappt Prima! Ohne das Du jetzt Werbung
betreiben müßtest, kannst Du mir vielleicht ein Buch empfehlen, wo ich diese
Dinge schnell und übersichtlich nachschlagen kann?

Beste Grüße
diskskin
Mitglied: diskskin
diskskin 25.11.2008 um 11:18:20 Uhr
Goto Top
Moin nochmal,

wenn ich den Zeitraum von einem Monat haben möchte, dann kann ich doch
auch folgendes schreiben:

WHERE DATEDIFF(month, [Datum aus der Datenbank], CURRENT_TIMESTAMP) <= 1;

Oder?

Beste Grüße
ds
Mitglied: Biber
Biber 25.11.2008 um 13:16:51 Uhr
Goto Top
Moin diskskin,

natürlich kannst Du das schreiben, ist ja ein freies Land hier.
Aber einen Unterschied macht es trotzdem.
Denn Du hättest, wenn es sich bei den Datumswerten zufällig um den 1.12.2008 und den 31.1.2009 handeln würde,auch nur "einen Monat oder weniger" Unterschied, da die Datediff()-Implementierung nur ganzzahl-Werte rückliefert.
Aber in diesem Fall würden bei Dir ca. 60 und damit doppelt so viele Tage berücksichtigt als meine 30 Tage.

Zum Nachschlagen bei MS-SQL benutze ich ich meist die BOL oder MSDN - habe da selbst nichts in Papierform.

Grüße
Biber
Mitglied: diskskin
diskskin 25.11.2008 um 13:21:11 Uhr
Goto Top
Alles klar. Danke.

Ja, ich habe das Statement jetzt so umgebaut, dass nur Datensätze geliefert
werden, die aus dem aktuellen Monaten stammen:

(DATEDIFF(month, [Datum aus der DB], CURRENT_TIMESTAMP) = 0)

Klappt auch wunderbar!

Beste Grüße
ds
Mitglied: Biber
Biber 25.11.2008 um 15:24:00 Uhr
Goto Top
Moin siskskin,

letzter Nachtrag:

ich will mir ja nicht den Ruf eines Erbsenzählers einhandeln, aber...face-wink

"Alle Datensätze aus dem aktuellen Monat" ist wieder etwas ganz anderes und weder gleichbedeutend mit "max. 30 Tage alt" noch mit "Anzahl Monate zwischen den Datumswerten kleiner gleich 1".

Welche Variante Du fachlich/inhaltlich benötigst, das kannst nur Du einschätzen, aber Du solltest diese Abfragen nicht mischen/nicht als austauschbar ansehen.

Grüße
Biber