是否可以仅从一列合并 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 |
+--------+--------+----------+
我想知道是否可以从 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 |
+--------+--------+----------+