Heim > Datenbank > MySQL-Tutorial > Wie erstelle ich trotz Lücken in den Quelldaten eine vollständige Datumsbereichstabelle in SQL Server 2000?

Wie erstelle ich trotz Lücken in den Quelldaten eine vollständige Datumsbereichstabelle in SQL Server 2000?

Patricia Arquette
Freigeben: 2024-12-21 07:13:09
Original
507 Leute haben es durchsucht

How to Generate a Complete Date Range Table in SQL Server 2000 Despite Gaps in Source Data?

Erstellen einer temporären Datumsbereichstabelle in SQL Server 2000

Ihre Anforderung zum Erstellen einer temporären Tabelle mit Datumsangaben im Bereich von $startDate bis $endDate und zusätzlichem Platzhalter mit Nullwert Spalten stellen aufgrund möglicher Lücken in den Einfügedaten der Kundentabelle eine Herausforderung dar.

Um dieses Problem zu lösen, beachten Sie Folgendes Ansatz:

  1. Bereichsvariablen deklarieren: Wie Sie es bereits getan haben, verwenden Sie die folgenden Deklarationen, um die minimalen und maximalen Einfügedaten zu erfassen:

    declare $startDate set $startDate = select min(InsertDate) from customer
    declare $endDate set $endDate = select max(InsertDate) from customer
    Nach dem Login kopieren
  2. Erstellen Sie eine Dummy-Datumstabelle: Erstellen Sie mithilfe des Schemas Ihrer temporären Tabelle eine Dummy-Tabelle mit Datumsangaben von $startDate bis $endDate mithilfe einer Schleife:

    CREATE TABLE #dates (
     Month DATE,
     Trials INT DEFAULT 0,
     Sales INT DEFAULT 0
    );
    Nach dem Login kopieren
  3. Dummy-Datumstabelle füllen: Um die Vollständigkeit sicherzustellen, verwenden Sie einen Cursor zum Durchlaufen Der Datumsbereich von $startDate bis $endDate, wobei jedes Datum in den Dummy eingefügt wird Tabelle:

    DECLARE @d DATE = $startDate;
    
    WHILE @d <= $endDate
    BEGIN
     INSERT INTO #dates (Month) VALUES (@d);
     SET @d = DATEADD(DAY, 1, @d);
    END;
    Nach dem Login kopieren

Dieser Ansatz generiert dynamisch einen vollständigen Datumsbereich innerhalb des angegebenen Bereichs, unabhängig von Lücken in der Kundentabelle. Sie können diese Dummy-Tabelle dann als Quelle zum Füllen Ihrer temporären Datumsbereichstabelle verwenden.

Das obige ist der detaillierte Inhalt vonWie erstelle ich trotz Lücken in den Quelldaten eine vollständige Datumsbereichstabelle in SQL Server 2000?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage