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>
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>
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!