• <bdo id='3UOh7'></bdo><ul id='3UOh7'></ul>

      <i id='3UOh7'><tr id='3UOh7'><dt id='3UOh7'><q id='3UOh7'><span id='3UOh7'><b id='3UOh7'><form id='3UOh7'><ins id='3UOh7'></ins><ul id='3UOh7'></ul><sub id='3UOh7'></sub></form><legend id='3UOh7'></legend><bdo id='3UOh7'><pre id='3UOh7'><center id='3UOh7'></center></pre></bdo></b><th id='3UOh7'></th></span></q></dt></tr></i><div id='3UOh7'><tfoot id='3UOh7'></tfoot><dl id='3UOh7'><fieldset id='3UOh7'></fieldset></dl></div>

      <small id='3UOh7'></small><noframes id='3UOh7'>

      <tfoot id='3UOh7'></tfoot>
        <legend id='3UOh7'><style id='3UOh7'><dir id='3UOh7'><q id='3UOh7'></q></dir></style></legend>

        将子查询中的多个结果合并为一个以逗号分隔的值

        Combine multiple results in a subquery into a single comma-separated value(将子查询中的多个结果合并为一个以逗号分隔的值)

            <small id='JEDzW'></small><noframes id='JEDzW'>

            <legend id='JEDzW'><style id='JEDzW'><dir id='JEDzW'><q id='JEDzW'></q></dir></style></legend>
            • <bdo id='JEDzW'></bdo><ul id='JEDzW'></ul>
              <i id='JEDzW'><tr id='JEDzW'><dt id='JEDzW'><q id='JEDzW'><span id='JEDzW'><b id='JEDzW'><form id='JEDzW'><ins id='JEDzW'></ins><ul id='JEDzW'></ul><sub id='JEDzW'></sub></form><legend id='JEDzW'></legend><bdo id='JEDzW'><pre id='JEDzW'><center id='JEDzW'></center></pre></bdo></b><th id='JEDzW'></th></span></q></dt></tr></i><div id='JEDzW'><tfoot id='JEDzW'></tfoot><dl id='JEDzW'><fieldset id='JEDzW'></fieldset></dl></div>
            • <tfoot id='JEDzW'></tfoot>
                  <tbody id='JEDzW'></tbody>

                  本文介绍了将子查询中的多个结果合并为一个以逗号分隔的值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我有两张桌子:

                  TableA
                  ------
                  ID,
                  Name
                  
                  TableB
                  ------
                  ID,
                  SomeColumn,
                  TableA_ID (FK for TableA)
                  

                  关系是一行TableA - 许多TableB.

                  The relationship is one row of TableA - many of TableB.

                  现在,我想看到这样的结果:

                  Now, I want to see a result like this:

                  ID     Name      SomeColumn
                  
                  1.     ABC       X, Y, Z (these are three different rows)
                  2.     MNO       R, S
                  

                  这不起作用(子查询中有多个结果):

                  This won't work (multiple results in a subquery):

                  SELECT ID,
                         Name, 
                         (SELECT SomeColumn FROM TableB WHERE F_ID=TableA.ID)
                  FROM TableA
                  

                  如果我在客户端进行处理,这是一个微不足道的问题.但这意味着我必须在每个页面上运行 X 次查询,其中 X 是 TableA 的结果数.

                  This is a trivial problem if I do the processing on the client side. But this will mean I will have to run X queries on every page, where X is the number of results of TableA.

                  请注意,我不能简单地执行 GROUP BY 或类似操作,因为它会为 TableA 的行返回多个结果.

                  Note that I can't simply do a GROUP BY or something similar, as it will return multiple results for rows of TableA.

                  我不确定使用 COALESCE 或类似方法的 UDF 是否可行?

                  I'm not sure if a UDF, utilizing COALESCE or something similar might work?

                  推荐答案

                  1.创建 UDF:

                  CREATE FUNCTION CombineValues
                  (
                      @FK_ID INT -- The foreign key from TableA which is used 
                                 -- to fetch corresponding records
                  )
                  RETURNS VARCHAR(8000)
                  AS
                  BEGIN
                  DECLARE @SomeColumnList VARCHAR(8000);
                  
                  SELECT @SomeColumnList =
                      COALESCE(@SomeColumnList + ', ', '') + CAST(SomeColumn AS varchar(20)) 
                  FROM TableB C
                  WHERE C.FK_ID = @FK_ID;
                  
                  RETURN 
                  (
                      SELECT @SomeColumnList
                  )
                  END
                  

                  2.在子查询中使用:

                  SELECT ID, Name, dbo.CombineValues(FK_ID) FROM TableA
                  

                  3.如果您使用的是存储过程,您可以这样做:

                  CREATE PROCEDURE GetCombinedValues
                   @FK_ID int
                  As
                  BEGIN
                  DECLARE @SomeColumnList VARCHAR(800)
                  SELECT @SomeColumnList =
                      COALESCE(@SomeColumnList + ', ', '') + CAST(SomeColumn AS varchar(20)) 
                  FROM TableB
                  WHERE FK_ID = @FK_ID 
                  
                  Select *, @SomeColumnList as SelectedIds
                      FROM 
                          TableA
                      WHERE 
                          FK_ID = @FK_ID 
                  END
                  

                  这篇关于将子查询中的多个结果合并为一个以逗号分隔的值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Select n random rows from SQL Server table(从 SQL Server 表中随机选择 n 行)
                  SQL query to select dates between two dates(用于选择两个日期之间的日期的 SQL 查询)
                  How can I delete using INNER JOIN with SQL Server?(如何在 SQL Server 中使用 INNER JOIN 进行删除?)
                  Table Naming Dilemma: Singular vs. Plural Names(表命名困境:单数与复数名称)
                  INSERT statement conflicted with the FOREIGN KEY constraint - SQL Server(INSERT 语句与 FOREIGN KEY 约束冲突 - SQL Server)
                  Optimal way to concatenate/aggregate strings(连接/聚合字符串的最佳方式)

                      <tbody id='wikCu'></tbody>
                  1. <small id='wikCu'></small><noframes id='wikCu'>

                  2. <i id='wikCu'><tr id='wikCu'><dt id='wikCu'><q id='wikCu'><span id='wikCu'><b id='wikCu'><form id='wikCu'><ins id='wikCu'></ins><ul id='wikCu'></ul><sub id='wikCu'></sub></form><legend id='wikCu'></legend><bdo id='wikCu'><pre id='wikCu'><center id='wikCu'></center></pre></bdo></b><th id='wikCu'></th></span></q></dt></tr></i><div id='wikCu'><tfoot id='wikCu'></tfoot><dl id='wikCu'><fieldset id='wikCu'></fieldset></dl></div>
                      • <bdo id='wikCu'></bdo><ul id='wikCu'></ul>
                        <legend id='wikCu'><style id='wikCu'><dir id='wikCu'><q id='wikCu'></q></dir></style></legend>
                        1. <tfoot id='wikCu'></tfoot>