October 24, 2022 at 6:08 am
October 24, 2022 at 7:39 am
Without knowing how the underlying tables are structured, it's impossible to provide a coded answer. However, I suspect a combination of STRING_AGG() and GROUP BY should get you there. Some examples here.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
October 24, 2022 at 7:44 am
Maybe like this:
DROP TABLE IF EXISTS #SomeData;
CREATE TABLE #SomeData
(
Name VARCHAR(50)
,Value VARCHAR(50)
);
INSERT #SomeData
(
Name
,Value
)
VALUES
('A', 'X')
,('A', 'Y')
,('A', 'Z')
,('B', 'X')
,('B', 'Y');
SELECT sd.Name
,Value = STRING_AGG(sd.Value, ',')WITHIN GROUP(ORDER BY sd.Value)
FROM #SomeData sd
GROUP BY sd.Name;
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
October 24, 2022 at 7:21 pm
Reminder... STRING_AGG() wasn't available until 2017. The OP posted in a 2016 forum.
--Jeff Moden
Change is inevitable... Change for the better is not.
October 24, 2022 at 11:01 pm
First, welcome aboard. Just to help you on your postings, graphics are great for posting what you want to see or for additional explanations. Most folks on this forum like to test their code against your data to make sure that they're provided a correct result. Graphics of the input data don't help that cause.
With that, please see the article at the first link in my signature line below. Providing "Readily Consumable Data" will help us help you with better answers more quickly.
Here's an example of one way you could have posted the sample data for this particular post.
DROP TABLE IF EXISTS #MyHead; --To make reruns easier
;
SELECT v.Name, v.Value
INTO #MyHead
FROM (VALUES
('A','X')
,('A','Y')
,('A','Z')
,('B','X')
,('B','Y')
,('C','W')
,('C','X')
,('C','Y')
,('C','Z')
)v(Name,Value)
;
Getting to the problem you posted, STRING_AGG() isn't available until SQL Server 2017. You've posted in a 2016 forum so I'm assuming that's what you're using.
The following will produce the required concatenation to create the CSVs by Name. If you need the Value column with the individual entries, as in your original post, you have to join the output of this code back to the original source to get it.
SELECT Name
,Combine = STUFF(
(
SELECT N','+t2.Value
FROM #MyHead t2
WHERE t2.Name = t1.Name
ORDER BY t2.Value
FOR XML PATH(''), TYPE
).value('./text()[1]','NVARCHAR(MAX)')
,1,1,N'')
FROM #MyHead t1
GROUP BY Name
ORDER BY Name
;
The XML PATH subquery does all the real work. The STUFF is used to remove the leading comma that the XML PATH can't help but make. Here's the output from that using the test data I provided.
--Jeff Moden
Change is inevitable... Change for the better is not.
October 25, 2022 at 10:07 am
Reminder... STRING_AGG() wasn't available until 2017. The OP posted in a 2016 forum.
Thanks, Jeff, I should have checked that!
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
October 25, 2022 at 1:54 pm
Jeff Moden wrote:Reminder... STRING_AGG() wasn't available until 2017. The OP posted in a 2016 forum.
Thanks, Jeff, I should have checked that!
Not to worry... I've been bitten by that type of thing so often that it's (finally) one of the first things that I look at. The really good part about such "mistakes" is that they show how much simpler some code can be thanks to an upgrade. I have a deep hatred for the FOR XML PATH method, especially since the addition of TYPE to provide de-entitization of characters makes it run twice as slow but you almost dare not skip it because someone will use it in a place where it matters.
--Jeff Moden
Change is inevitable... Change for the better is not.
Viewing 7 posts - 1 through 6 (of 6 total)
You must be logged in to reply to this topic. Login to reply