SQL,关于join的问题

标签 sql sql-server-2008 tsql

我在 sql 2012 中有两个表:name 和 prod 结构:

名称:id int increment, name1 nvarchar(50)

prod:id int increment, products nvarchar(50), id_name int

表的值是:

名称表:

Id   name1
1    pop
2    andi

产品表:

Id   products   id_name
1    coke       1
2    pizza      1
3    orange     2

我已经完成了这个查询:

select name.name1, prod.product, prod.id_name
from name
join prod on name.id=prod.id_name

我怎样才能得到这个结果:

pop ->coke, pizza
andi->orange  

最佳答案

不幸的是,在 SQL Server 中没有简单的方法可以做到这一点。已知的解决方案是:

  • xml 技巧(见下文);
  • 使用变量累积数据(不适用于多组行,仅适用于游标);
  • 自定义 CLR 聚合;

这是 xml:

select
    n.name1,
    stuff(
        (
         select ', ' + p.product
         from prod as p
         where p.id_name = n.id
         for xml path(''),  type).value('.', 'nvarchar(max)')
    , 1, 2, '') as products
from name as n

sql fiddle demo

这是变量:

declare @product nvarchar(max), @id int

select @id = 1

select @product = isnull(@product + ', ', '') + product
from prod
where id_name = @id

select name1, @product as products
from name 
where id = @id

sql fiddle demo

关于SQL,关于join的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18335157/

相关文章:

sql - 结束于 where 子句

php - 如何让表格内容自动以弹出形式显示

sql - SQL、PL-SQL 和 T-SQL 之间有什么区别?

MySQL count + rollup 对查询问题进行小计

sql - 所需的列百分比

sql - 在 MS SQL Server 2008 中创建序列

c# - Entity Framework 多重聚合性能

sql - TSQL 根据最大​​的其他列的组合检索最大行

sql - 按排序值选择单个字段

sql - 笛卡尔积期间下标超出范围错误