| Author | Topic | 
                            
                                    | yoyoshStarting Member
 
 
                                        27 Posts | 
                                            
                                            |  Posted - 2013-02-27 : 07:19:05 
 |  
                                            | I would like to convert 1:N relation into comma-separated value in one column. Suppose we have the following tables:A:pk|col2_______1 | (empty string)2 | (empty string)B:pk|fk|col3__________1 |1 | a2 |1 | b3 |2 | cI want to update col2 in table A in the following way:A:pk|col2_______1 | a,b2 | cI tried something like that:UPDATE A SET col2 += col3from A INNER JOIN B on A.pk = B.fkThank you for help in advance |  | 
       
                            
                       
                          
                            
                                    | James KMaster Smack Fu Yak Hacker
 
 
                                    3873 Posts | 
                                        
                                          |  Posted - 2013-02-27 : 07:51:36 
 |  
                                          | [code]UPDATE A SET	col2 = STUFF(b.col3concat,1,1,'')FROM	A	CROSS APPLY	(		SELECT ',' + b.col3		FROM B 		WHERE b.fk = a.pk		FOR XML PATH('')	) c(col3concat);[/code] |  
                                          |  |  | 
                            
                       
                          
                            
                                    | visakh16Very Important crosS Applying yaK Herder
 
 
                                    52326 Posts | 
                                        
                                          |  Posted - 2013-02-27 : 22:59:43 
 |  
                                          | quote:Fixed typo------------------------------------------------------------------------------------------------------SQL Server MVPhttp://visakhm.blogspot.com/Originally posted by James K
 
 UPDATE A SET	col2 = STUFF(bc.col3concat,1,1,'')FROM	A	CROSS APPLY	(		SELECT ',' + b.col3		FROM B 		WHERE b.fk = a.pk		FOR XML PATH('')	) c(col3concat); 
 |  
                                          |  |  | 
                            
                       
                          
                            
                                    | yoyoshStarting Member
 
 
                                    27 Posts | 
                                        
                                          |  Posted - 2013-02-28 : 03:19:16 
 |  
                                          | quote:Thank you for response.Could you please explain:c(col3concat) ?What is 'c' here?Also second question: is XML PATH necessary in this query?Originally posted by James K
 
 UPDATE A SET	col2 = STUFF(b.col3concat,1,1,'')FROM	A	CROSS APPLY	(		SELECT ',' + b.col3		FROM B 		WHERE b.fk = a.pk		FOR XML PATH('')	) c(col3concat);
 |  
                                          |  |  | 
                            
                       
                          
                            
                                    | visakh16Very Important crosS Applying yaK Herder
 
 
                                    52326 Posts | 
                                        
                                          |  Posted - 2013-02-28 : 04:01:41 
 |  
                                          | quote:c is short name for the table called table aliasFOR XML PATH is that which causes the concatenation of the string------------------------------------------------------------------------------------------------------SQL Server MVPhttp://visakhm.blogspot.com/Originally posted by yoyosh
 
 quote:Thank you for response.Could you please explain:c(col3concat) ?What is 'c' here?Also second question: is XML PATH necessary in this query?Originally posted by James K
 
 UPDATE A SET	col2 = STUFF(b.col3concat,1,1,'')FROM	A	CROSS APPLY	(		SELECT ',' + b.col3		FROM B 		WHERE b.fk = a.pk		FOR XML PATH('')	) c(col3concat);
 
 |  
                                          |  |  | 
                            
                       
                          
                            
                                    | yoyoshStarting Member
 
 
                                    27 Posts | 
                                        
                                          |  Posted - 2013-02-28 : 05:30:53 
 |  
                                          | Why is alias followed by (...)?c(col3concat) |  
                                          |  |  | 
                            
                       
                          
                            
                                    | James KMaster Smack Fu Yak Hacker
 
 
                                    3873 Posts | 
                                        
                                          |  Posted - 2013-02-28 : 05:40:14 
 |  
                                          | It is telling SQL Server that what comes out from the subquery is a virtual table, and that I want to name that virtual table as "c", and that there will be one column in that table, and that I want to name that column as col3concat.  I could name it anything I want - for example: UPDATE A SET	col2 = STUFF(foo.bar,1,1,'')FROM	A	CROSS APPLY	(		SELECT ',' + b.col3		FROM B 		WHERE b.fk = a.pk		FOR XML PATH('')	) AS foo(bar);Why foo and bar? I have no idea! People seem to like foo and bar for things for which they cannot come up with reasonable names. I am sure there is a very good reason for it, but I don't know what that is. |  
                                          |  |  | 
                            
                       
                          
                            
                                    | LampreyMaster Smack Fu Yak Hacker
 
 
                                    4614 Posts |  | 
                            
                       
                          
                            
                                    | James KMaster Smack Fu Yak Hacker
 
 
                                    3873 Posts | 
                                        
                                          |  Posted - 2013-02-28 : 12:43:31 
 |  
                                          | A man-page for foo bar! Another one from Wiki with pictures and all: http://en.wikipedia.org/wiki/Foobar |  
                                          |  |  | 
                            
                       
                          
                            
                                    | yoyoshStarting Member
 
 
                                    27 Posts | 
                                        
                                          |  Posted - 2013-03-04 : 03:50:37 
 |  
                                          | Thanks |  
                                          |  |  | 
                            
                            
                                |  |