|
Posted by Erland Sommarskog on 08/20/06 12:38
rcamarda (robc390@hotmail.com) writes:
> I wish to build a table based on values from another table.
> I need to populate a table between two dates from another table. Using
> the START_DT and END_DT, create records between those dates.
> I need a new column that is the days between the date and the MID_DT
> The data I wish to end with would look something like this:
>
> PERIOD DATE DAY_NO
> 200602 2005-07-06 -89
> 200602 2005-07-07 -88
> 200602 2005-07-08 -87
><...>
> 200602 2005-10-02 -2
> 200602 2005-10-03 -1
> 200602 2005-10-04 0
> 200602 2005-10-05 1
><...>
> 200602 2005-12-18 75
>
> CREATE TABLE "dbo"."tblDates"
> ("PERIOD" CHAR(6) NOT NULL,
> "START_DT" DATETIME NULL,
> "MID_DT" DATETIME NULL,
> "END_DT" DATETIME NOT NULL)
>
> INSERT INTO tblDates VALUES('200505',2005-04-12,2005-07-05,2005-09-12)
> INSERT INTO tblDates VALUES('200602',2005-07-06,2005-10-03,2005-12-18)
> INSERT INTO tblDates VALUES('200603',2005-10-04,2006-01-17,2006-03-27)
> INSERT INTO tblDates VALUES('200604',2006-01-18,2006-04-10,2006-06-19)
> INSERT INTO tblDates VALUES('200605',2006-04-11,2006-07-04,2006-09-11)
> INSERT INTO tblDates VALUES('200702',2006-07-05,2006-10-02,2006-12-18)
Thanks for posting table definition and data. However, I would appreciate
if you also tested your repro script before you post. I was puzzled not
getting any rows back first from my query, but then I realised that
2005-04-12 > 2005-09-12. (Run the above folliwed by a SELECT on the
table to see why.)
Anyway, as I said in another newsgroup, you need a table of numbers. Here
is a way to create such a table with a million numbers:
CREATE TABLE Numbers (Number int NOT NULL PRIMARY KEY);
WITH digits (d) AS (
SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION
SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION
SELECT 7 UNION SELECT 8 UNION SELECT 9 UNION
SELECT 0)
INSERT Numbers (Number)
SELECT Number
FROM (SELECT i.d + ii.d * 10 + iii.d * 100 + iv.d * 1000 +
v.d * 10000 + vi.d * 100000 AS Number
FROM digits i
CROSS JOIN digits ii
CROSS JOIN digits iii
CROSS JOIN digits iv
CROSS JOIN digits v
CROSS JOIN digits vi) AS Numbers
WHERE Number > 0
Given this table, we can write this query:
SELECT d.PERIOD, dateadd(DAY, n.Number - 1, d.START_DT),
datediff(DAY, d.MID_DT, dateadd(DAY, n.Number - 1, d.START_DT))
FROM tblDates d
CROSS JOIN Numbers n
WHERE dateadd(DAY, n.Number - 1, d.START_DT)
BETWEEN d.START_DT AND d.END_DT
ORDER BY d.PERIOD, 2
--
Erland Sommarskog, SQL Server MVP, esquel@sommarskog.se
Books Online for SQL Server 2005 at
http://www.microsoft.com/technet/prodtechnol/sql/2005/downloads/books.mspx
Books Online for SQL Server 2000 at
http://www.microsoft.com/sql/prodinfo/previousversions/books.mspx
[Back to original message]
|