Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
217 views
in Technique[技术] by (71.8m points)

Create table in Microsoft SQL Server based on Distinct result set

My use case is to create rows for every month based on result set of distinct values which doesn't contain a YYYYMM date attached to it.

Example distinct data result set

columns: Name, Age, Working Hours

  • Miquell, 25, 160

Expected Result

columns: Name, Age, Working Hours, Date(YYYYMM) for 2 years per month (202001, 202002, 202003 etc)

Miquell, 25, 160, 202001
Miquell, 25, 160, 202002
Miquell, 25, 160, 202003

Can this be done in a easy solution? Copying the data with a timestamp and keep on adjusting and adding to a temp table when i change the month values doesn't seem very user friendly.

Thanks for the help,


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

You can use a recursive CTE that computes the date and finally join to the row(s) you have.

WITH
Recursion AS
(
SELECT CAST('2020-01-01' AS date) AS D
UNION ALL
SELECT DATEADD(MONTH, 1, D)
FROM   Recursion
WHERE  D < '2100-12-01'
)
SELECT 'Miquell' AS Name, 25 AS Age, 160 AS WorkingHours, CONVERT(CHAR(6), D, 112)
FROM   Recursion
OPTION (maxrecursion 0);

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...