Heim > Datenbank > MySQL-Tutorial > Wie erstelle ich einen Datumsbereich für den Aufenthalt mehrerer Gäste in SQL Server?

Wie erstelle ich einen Datumsbereich für den Aufenthalt mehrerer Gäste in SQL Server?

Linda Hamilton
Freigeben: 2025-01-10 11:10:42
Original
724 Leute haben es durchsucht

How to Generate a Date Range for Multiple Guests' Stays in SQL Server?

Wie erstelle ich einen Datumsbereich für Check-in-Daten mehrerer Gäste in SQL Server?

In diesem Artikel wird eine effiziente Methode zum Generieren täglicher Datensätze in SQL Server für jeden Gast während seines Aufenthalts vorgestellt. Diese Methode unterscheidet sich geringfügig vom Titel „So generieren Sie einen Datumsbereich in SQL Server“ und konzentriert sich mehr auf die Erstellung täglicher Check-in-Datensätze für jeden Gast. Dies erreichen wir mithilfe von Common Table Expressions (CTEs).

Lösung:

Die folgende Abfrage kombiniert geschickt die Funktionen CTE und ROW_NUMBER(), um eine Datumssequenz zu generieren, die den gesamten Aufenthalt des Gastes abdeckt:

<code class="language-sql">DECLARE @start DATE, @end DATE;
SELECT @start = '20110714', @end = '20110717';

;WITH n AS 
(
  SELECT TOP (DATEDIFF(DAY, @start, @end) + 1) 
    n = ROW_NUMBER() OVER (ORDER BY [object_id])
  FROM sys.all_objects
)
SELECT 'Bob', DATEADD(DAY, n-1, @start)
FROM n;</code>
Nach dem Login kopieren

Ergebnis:

宾客姓名 日期
Bob 2011-07-14
Bob 2011-07-15
Bob 2011-07-16
Bob 2011-07-17

Auf mehrere Gäste erweitern:

Um mehrere Gäste unterzubringen, können wir einen zweiten CTE verwenden, um den Gästetisch mit der generierten Datumssequenz zu verbinden:

<code class="language-sql">DECLARE @t TABLE
(
    Member NVARCHAR(32), 
    RegistrationDate DATE, 
    CheckoutDate DATE
);

INSERT @t SELECT N'Bob', '20110714', '20110717'
UNION ALL SELECT N'Sam', '20110712', '20110715'
UNION ALL SELECT N'Jim', '20110716', '20110719';

;WITH [range](d,s) AS 
(
  SELECT DATEDIFF(DAY, MIN(RegistrationDate), MAX(CheckoutDate))+1,
    MIN(RegistrationDate)
    FROM @t 
),
n(d) AS
(
  SELECT DATEADD(DAY, n-1, (SELECT MIN(s) FROM [range]))
  FROM (SELECT ROW_NUMBER() OVER (ORDER BY [object_id])
  FROM sys.all_objects) AS s(n)
  WHERE n <= (SELECT MAX(d) FROM [range])
)
SELECT t.Member, n.d
FROM n CROSS JOIN @t AS t
WHERE n.d BETWEEN t.RegistrationDate AND t.CheckoutDate;</code>
Nach dem Login kopieren

Ergebnis:

宾客姓名 日期
Bob 2011-07-14
Bob 2011-07-15
Bob 2011-07-16
Bob 2011-07-17
Sam 2011-07-12
Sam 2011-07-13
Sam 2011-07-14
Sam 2011-07-15
Jim 2011-07-16
Jim 2011-07-17
Jim 2011-07-18
Jim 2011-07-19

Das obige ist der detaillierte Inhalt vonWie erstelle ich einen Datumsbereich für den Aufenthalt mehrerer Gäste in SQL Server?. 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