是否可以仅从一列合并 SQL 中的行?

Is it Possible to Merge Rows in SQL from Just One Column?

我想知道是否可以从 SQL 中的一列中合并多行。这是我的初始示例 table:

Column 1 | Column 2 | Column 3
______________________________

DAVID    | 10.000   | Client 1
DAVID    | 5.000    | Client 2
DAVID    | 12.000   | Client 3
ANDREW   | 2.000    | Client 4
ANDREW   | 3.000    | Client 5

这是我的预期输出:

Column 1 | Column 2 | Column 3
______________________________

DAVID    | 10.000   | Client 1
         | 5.000    | Client 2
         | 12.000   | Client 3
ANDREW   | 2.000    | Client 4
         | 3.000    | Client 5

不知道能不能像后面的那样table。因此,任何建议将不胜感激。

此类任务通常在应用程序的表示层而不是在数据库中完成。

但它可以在 SQL 中完成 - 前提是您有一个定义行排序的列!说:id.

select
    case when row_number() over(partition by col1 order by id) = 1 then col1 end as col1,
    col2,
    col3
from mytable
order by col1, id

一般我们在excel中展示报表的时候都会这样展示。但是,如果你想在SQL服务器中看到这种报告,你可以使用LAG功能,然后相应地获取数据。

DECLARE @table table(col1 varchar(20), col2 DECIMAL(5,3), col3 varchar(20))

INSERT INTO @table
values
('DAVID', 10.000   ,'Client 1'),
('DAVID', 5.000    ,'Client 2'),
('DAVID', 12.000   ,'Client 3'),
('ANDREW', 2.000   ,'Client 4'),
('ANDREW', 3.000   ,'Client 5');

--SELECT CASE WHEN col1 = prev then '' ELSE col1 END, col2, col3
select case when prev is null then col1
            when prev <> col1 then col1 
            when prev = col1 then ''
            end as col1, col2, col3

from
(
SELECT col1,lag(COL1,1) over(order by col1) as prev, col2, col3
FROM @TABLE
) as t

+--------+--------+----------+
|  col1  |  col2  |   col3   |
+--------+--------+----------+
| ANDREW |  2.000 | Client 4 |
|        |  3.000 | Client 5 |
| DAVID  | 10.000 | Client 1 |
|        |  5.000 | Client 2 |
|        | 12.000 | Client 3 |
+--------+--------+----------+