怎么把子查询的集合 转换成主查询的一个字段?

班级表
id class
1 一班
2 二班
学生表
id student_name class_id
1 小明 1
2 小红 1
3 小宝 2
4 小小 2
这种的会写
select class , student_name from
student_name a
left join class b
on a.class_id=b.id

返回的实体类
{
string class;
string name;
}
class student_name
一班 小明
一般 小红
二班 小宝
二班 小小

或者集合这种也会写
一班: [ { 1,小明,1},{ 2,小红,1} ]
二班:[ {3,小宝,2},{4,小小,2}]
返回的实体类
{
string class;
List student;
}

想要这样的结果
返回的实体类
{
string class;
string name;
}

班级 学生
一班 小红,小明
二班 小宝,小小

解决办法 sql
select class_name ,GROUP_CONCAT(student_name)
from
student a
left join class b
on a.class_id=b.id
GROUP BY class_name

第二中方法:执行中不好用(参考)
https://zhidao.baidu.com/question/248830470.html?fr=iks&word=for+xml+path(%26%2339%3B%26%2339%3B))%2C1%2C1%2C&ie=gbk

转自 ;https://www.cnblogs.com/yasuo2/p/6433697.html
FOR XML PATH 函数用法
一.FOR XML PATH 简单介绍

         那么还是首先来介绍一下FOR XML PATH ,假设现在有一张兴趣爱好表(hobby)用来存放兴趣爱好,表结构如下:

   接下来我们来看应用FOR XML PATH的查询结果语句如下:

SELECT * FROM @hobby FOR XML PATH
结果:

复制代码
复制代码

1
爬山


2
游泳


3
美食

复制代码
复制代码
由此可见FOR XML PATH 可以将查询结果根据行输出成XML各式!

  那么,如何改变XML行节点的名称呢?代码如下:     

SELECT * FROM @hobby FOR XML PATH(‘MyHobby’)

  结果一定也可想而知了吧?没错原来的行节点<row> 变成了我们在PATH后面括号()中,自定义的名称<MyHobby>,结果如下:

复制代码
复制代码

1
爬山


2
游泳


3
美食

复制代码
复制代码
这个时候细心的朋友一定又会问那么列节点如何改变呢?还记的给列起别名的关键字AS吗?对了就是用它!代码如下:

SELECT hobbyID as ‘MyCode’,hName as ‘MyName’ FROM @hobby FOR XML PATH(‘MyHobby’)

  那么这个时候我们列的节点名称也会编程我们自定义的名称 <MyCode>与<MyName>结果如下:

复制代码
复制代码

1
爬山


2
游泳


3
美食

复制代码
复制代码
噢! 既然行的节点与列的节点我们都可以自定义,我们是否可以构建我们喜欢的输出方式呢?还是看代码:

SELECT ‘[ ‘+hName+’ ]’ FROM @hobby FOR XML PATH(’’)
没错我们还可以通过符号+号,来对字符串类型字段的输出格式进行定义。结果如下:

[ 爬山 ][ 游泳 ][ 美食 ]
那么其他类型的列怎么自定义? 没关系,我们将它们转换成字符串类型就行啦!例如:

SELECT ‘{’+STR(hobbyID)+’}’,’[ ‘+hName+’ ]’ FROM @hobby FOR XML PATH(’’)
好的 FOR XML PATH就基本介绍到这里吧,更多关于FOR XML的知识请查阅帮助文档!

接下来我们来看一个FOR XML PATH的应用场景吧!那么开始吧。。。。。。

    二.一个应用场景与FOR XML PATH应用

    首先呢!我们在增加一张学生表,列分别为(stuID,sName,hobby),stuID代表学生编号,sName代表学生姓名,hobby列存学生的爱好!那么现在表结构如下:

       

    这时,我们的要求是查询学生表,显示所有学生的爱好的结果集,代码如下:

复制代码
复制代码
SELECT B.sName,LEFT(StuList,LEN(StuList)-1) as hobby FROM (
SELECT sName,
(SELECT hobby+’,’ FROM student
WHERE sName=A.sName
FOR XML PATH(’’)) AS StuList
FROM student A
GROUP BY sName
) B
复制代码
复制代码
结果如下:

分析: 好的,那么我们来分析一下,首先看这句:

SELECT hobby+’,’ FROM student
WHERE sName=A.sName
FOR XML PATH(’’)
这句是通过FOR XML PATH 将某一姓名如张三的爱好,显示成格式为:“ 爱好1,爱好2,爱好3,”的格式!

那么接着看:

复制代码
复制代码
SELECT B.sName,LEFT(StuList,LEN(StuList)-1) as hobby FROM (
SELECT sName,
(SELECT hobby+’,’ FROM student
WHERE sName=A.sName
FOR XML PATH(’’)) AS StuList
FROM student A
GROUP BY sName
) B
复制代码
复制代码
剩下的代码首先是将表分组,在执行FOR XML PATH 格式化,这时当还没有执行最外层的SELECT时查询出的结构为:

可以看到StuList列里面的数据都会多出一个逗号,这时随外层的语句:SELECT B.sName,LEFT(StuList,LEN(StuList)-1) as hobby 就是来去掉逗号,并赋予有意义的列明

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值