如何解决是否可以仅从一列合并SQL中的行?
我想知道是否可以合并SQL中仅一列的多行。这是我的初始表的示例:
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
我不知道是否可能有一个像上一个表那样的表。因此,任何建议将不胜感激。
解决方法
这类任务通常在应用程序的表示层而不是数据库中完成。
但是可以在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 Server中查看此类报告,可以使用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'),12.000,'Client 3'),('ANDREW',2.000,'Client 4'),3.000,'Client 5');
--SELECT CASE WHEN col1 = prev then '' ELSE col1 END,col3
select case when prev is null then col1
when prev <> col1 then col1
when prev = col1 then ''
end as col1,col3
from
(
SELECT col1,lag(COL1,1) over(order by col1) as prev,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 |
+--------+--------+----------+
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。