* tableA
* id name
* 1 张三
*
* tableB
* id a_id yifu
* 1 1 短袖
* 2 1 长袖
*
*
* 要求返回结果
* name b_id1 yifu1 b_id2 yifu2
* 张三 1 短袖 2 长袖
![](https://profile-avatar.csdnimg.cn/dc87dfc4f9e743b6b3c7e2c15e1ef61e_yy6991651.jpg!4)
如何使MySQL关联查询返回结果集中相同字段不同数据 只返回一条
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- 听雨停了 2019-09-19 14:43关注
列转行,然后在行转列就ok了。下面是sqlServer的代码,可以参考下。
--测试数据 use Tempdb go --> --> 听雨停了-->生成测试数据 if not object_id(N'Tempdb..#tabA') is null drop table #tabA Go Create table #tabA([id] int,[name] nvarchar(22)) Insert #tabA select 1,N'张三' Go Select * from #tabA use Tempdb go --> --> 听雨停了-->生成测试数据 if not object_id(N'Tempdb..#tabB') is null drop table #tabB Go Create table #tabB([id] int,[a_id] int,[yifu] nvarchar(22)) Insert #tabB select 1,1,N'短袖' union all select 2,1,N'长袖' Go Select * from #tabB --测试数据结束 SELECT NAME, id_1, yifu_1, id_2, yifu_2 FROM ( SELECT NAME, c + '_' + CONVERT(VARCHAR, rn) AS 'c', v FROM ( SELECT NAME, CONVERT(VARCHAR(10), id) AS id, CONVERT(VARCHAR(10), yifu) yifu, ROW_NUMBER() OVER(PARTITION BY NAME ORDER BY id) AS rn FROM ( SELECT a.name,b.id,b.yifu FROM #tabA AS a INNER JOIN #tabB AS b ON a.id=b.a_id )aa ) a UNPIVOT(v FOR c IN ([id], yifu)) u ) b PIVOT(MAX(v) FOR c IN (id_1, yifu_1, id_2, yifu_2)) p NAME id_1 yifu_1 id_2 yifu_2 ---------------------- ---------- ---------- ---------- ---------- 张三 1 短袖 2 长袖
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵