sql server 一列的多行内容拼接成一行中的一列
select ProjName,status from Project; --for xml path('') 是把得到的内容以XML的形式显示。 --stuff(param1, startIndex, length, param2) 将param1中自startIndex(SQL中都是从1开始,而非0)起,删除length个字符,然后用param2替换删掉的字符。 select ProjectName = ( stuff( (select '、' + ProjName from Project where Status = A.Status for xml path('')), 1, 1, '' ) ) from Project as A group by status;
xml path('')用法这里也详解:https://www.cnblogs.com/yuer20180726/p/11365498.html
二、普通行转列
准备:
-- 创建模拟数据CREATE TABLE #TempSubjectResult(StudentName NVARCHAR(50) NOT NULL,StudentSubject NVARCHAR(50) NOT NULL,StudentGrade DECIMAL(4,1) NOT NULL)INSERT INTO #TempSubjectResult(StudentName,StudentSubject,StudentGrade) VALUES ('小姚','语文','80')INSERT INTO #TempSubjectResult(StudentName,StudentSubject,StudentGrade) VALUES ('小姚','数学','70')INSERT INTO #TempSubjectResult(StudentName,StudentSubject,StudentGrade) VALUES ('小姚','英语','60')INSERT INTO #TempSubjectResult(StudentName,StudentSubject,StudentGrade) VALUES ('小明','语文','90')INSERT INTO #TempSubjectResult(StudentName,StudentSubject,StudentGrade) VALUES ('小明','数学','95')INSERT INTO #TempSubjectResult(StudentName,StudentSubject,StudentGrade) VALUES ('小明','英语','98') SELECT * FROM #TempSubjectResult
原数据结果:
1、普通写法:
-- 1 Case When普通版 SELECT StudentName 学生名, MAX(CASE WHEN StudentSubject='语文' THEN StudentGrade END) 语文, MAX(CASE WHEN StudentSubject='数学' THEN StudentGrade END) 数学, MAX(CASE WHEN StudentSubject='英语' THEN StudentGrade END) 英语 FROM #TempSubjectResult GROUP BY StudentName
2、PIVOT函数
SELECT *
FROM #TempSubjectResult
PIVOT(MAX(StudentGrade) FOR StudentSubject IN([语文],[数学],[英语])) T
结果:
参照:https://www.cnblogs.com/kylan/p/10844414.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现