表A中id与表B中aid为一对多的关系
例如:
表A:
| id | name |
| a1 | tom |
| a2 | lily |
| a3 | lucy |
表B:
| id | aid | value |
| b1 | a1 | B1 |
| b2 | a1 | B2 |
| b3 | a2 | B3 |
| b4 | a3 | B4 |
| b5 | a2 | B5 |
| b6 | a3 | B6 |
| b7 | a3 | B7 |
使用for path(\'\') 和stuff合并显示多行数据到一行中 :
第一种,不使用stuff,结果如下:
select id, [val]=( select [value] +\',\' from tb as b where b.id = a.id for path(\'\') ) from tb as a group by id
结果:
| id | val |
| a1 | B1,B2, |
| a2 | B3,B5, |
| a3 | B4,B6,B7, |
第二种,使用stuff将最后的逗号去掉
select id, [val]=stuff(( select \',\'+[value] from tb as b where b.id = a.id for path(\'\')),1,1,\'\') from tb as a group by id
结果:
| id | val |
| a1 | B1,B2 |
| a2 | B3,B5 |
| a3 | B4,B6,B7 |
继续阅读与本文标签相同的文章
上一篇 :
什么叫做真正的无人驾驶汽车?难道真的没有人么?
-
NEXT创新大会走进合肥,看“新经济”带“科创之都”腾飞。
2026-05-19栏目: 教程
-
win7系统想要用iis7远程桌面管理,可是他显示说你没有开通远程权限怎么解决?
2026-05-19栏目: 教程
-
好程序员大数据学习路线分享MapReduce全流程总结
2026-05-19栏目: 教程
-
什么是高防?有什么用?
2026-05-19栏目: 教程
-
阿里云如何添加CDN解析过程 新手必看教程
2026-05-19栏目: 教程
