余人_ 2019-09-19 11:42 采纳率: 100%
浏览 781
已采纳

如何使MySQL关联查询返回结果集中相同字段不同数据 只返回一条

* tableA
* id name 
* 1 张三
* 
* tableB
* id  a_id  yifu
* 1 1       短袖
* 2 1       长袖
* 
* 
* 要求返回结果
* name   b_id1      yifu1       b_id2    yifu2
* 张三       1             短袖        2             长袖
  • 写回答

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          长袖       
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 聚类分析或者python进行数据分析
  • ¥15 如何用visual studio code实现html页面
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?