Topyuluo 2015-04-12 01:44 采纳率: 100%
浏览 2029
已采纳

SQL Server 的一对多关系查询

图片说明

A表和B表是一对多关系,要如何写sql语句实现图中的效果。

  • 写回答

2条回答 默认 最新

  • danielinbiti 2015-04-12 02:20
    关注

    SQLServer如下

     CREATE TABLE A(
      id int,
      name varchar(20)
    );
    CREATE TABLE B(
      bid int,
      name varchar(20),
      pid int
    );
    insert into A(id,name) VALUES(1,'张三');
    insert into A(id,name) VALUES(2,'李四');
    insert into B(bid,name,PID) VALUES(1,'王五',1);
    insert into B(bid,name,PID) VALUES(2,'张飞',1);
    insert into B(bid,name,PID) VALUES(3,'钱六',2);
    
    select a.*,r.data from a left join(
    SELECT pid, data=STUFF((SELECT ','+name FROM b t WHERE pid=t1.pid FOR XML PATH('')), 1, 1, '')
    FROM b t1
    GROUP BY pid
    ) r on a.id=r.pid
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 安装svn网络有问题怎么办
  • ¥15 Python爬取指定微博话题下的内容,保存为txt
  • ¥15 vue2登录调用后端接口如何实现
  • ¥65 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥15 latex怎么处理论文引理引用参考文献