AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken MSSQL Schleife ueber einen gewissen Zeitraum
Thema durchsuchen
Ansicht
Themen-Optionen

MSSQL Schleife ueber einen gewissen Zeitraum

Ein Thema von Ajintaro · begonnen am 16. Feb 2012 · letzter Beitrag vom 17. Feb 2012
Antwort Antwort
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#1

AW: MSSQL Schleife ueber einen gewissen Zeitraum

  Alt 16. Feb 2012, 12:34
Folgende Anfrage liefert alle "Datümer" (ich weiss das die Mehrzahl von Datum Daten ist) und die Anzahl der Datensätze:
SQL-Code:
SELECT CONVERT(char(8), Zeitraum, 112) AS Datum, Count(*) AS Anzahl
FROM tabelle
GROUP BY CONVERT(char(8), Zeitraum, 112)
ORDER BY 1
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: MSSQL Schleife ueber einen gewissen Zeitraum

  Alt 16. Feb 2012, 13:01
Folgende Anfrage liefert alle "Datümer" (ich weiss das die Mehrzahl von Datum Daten ist)
lt. Denglish-Duden von 2015 (67,7 Auflage) ist der Plural von Datum "Datumse"

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

Registriert seit: 20. Okt 2004
Ort: Sankt Augustin
138 Beiträge
 
Delphi XE6 Starter
 
#3

AW: MSSQL Schleife ueber einen gewissen Zeitraum

  Alt 17. Feb 2012, 10:25
Danke fuer die vielen inspirierenden Antworten!

Ich habe mir jetzt eine Loesung zusammengebaut, welche das gewuenschte Ergebnis liefert: Die Tage ohne Eintragung ueber einen gewissen Zeitraum!

So siehts aus:

SQL-Code:
DECLARE @begindate DATETIME
DECLARE @begindate_end DATETIME
DECLARE @enddate DATETIME
DECLARE @i INT
DECLARE @diffdays INT

SET @i = 1
SET @begindate='2011-01-01 00:00:00'
SET @enddate='2012-02-17 23:59:59'
SET @diffdays=DATEDIFF(DAY, @begindate, @enddate)

WHILE (@i <= @diffdays+1)
BEGIN

SET @begindate_end = DATEADD(HOUR,23,@begindate)
SET @begindate_end = DATEADD(MINUTE,59,@begindate_end)
 
 IF NOT EXISTS (
 SELECT [telefonate]FROM [ABC].[dbo].[t_telefonate] WHERE LappenID = 2 AND FirstTime BETWEEN @begindate AND @begindate_end)
 BEGIN
   PRINT '*** Row NOT found between:'
   PRINT @begindate
   PRINT @begindate_end
   PRINT '----------------------------'
 END
 SET @begindate = DATEADD(DAY,1,@begindate)
  
 SET @i = @i + 1
END
Im Prinzip ganz einfach:
- Den Zeitraum bestimmen
- Differenz in Tagen ermitteln
- Schleife ueber den Zeitraum
- Den Tag von 0 Uhr bis 23:59 pruefen, kommt nix zurueck existiert kein Eintrag fuer den Tag
- Tagescounter hochzaehlen

Bestimmt unter aller Sau, funktioniert aber erstmal
Jaimy
DAoC 2.0 -> Camelot Unchained !
  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 10:19 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