2

我有两个表,TBL_PARENT (parentID, ParentName) 和 TBL_CHILDREN (ParentID,Child_Name) 一个 Parent 可以有 0 到多个孩子

我想要的是一个查询,让我在每个父母的单行中给我一个父母和他们的孩子的列表。

例如

Parent1 John,Mary

Parent2 jane,steve,jana

并且行数是父母的总数

4

2 回答 2

0
SELECT COUNT(P.parentID),
P.ParentName, 
C.Child_Name 
FROM TBL_PARENT as P
INNER JOIN TBL_CHILDREN as C  
WHERE P.parentID == c.ParentID
GROUP BY P.ParentName;

P.parentID == c.ParentID正在执行联接,行count(P.parentID)正在执行所有父项的计数,行GROUP BY P.ParentName正在按名称对所有行进行分组parent,以便您可以显示每个父母的所有孩子。

于 2013-08-15T14:31:44.100 回答
0

试试这个查询:我创建了 3 个表,其中 2 个已经在您的数据库 #parant、#ch 上创建,第三个是一个临时表,用于放入结果。

create table #parant (id int , name varchar(10))
create table #ch (id int , name varchar(10), pid int)

insert into #parant select 1,'PA'
insert into #parant select 2,'PB'
insert into #parant select 3,'PC'

insert into #ch select 1,'Ca',1
insert into #ch select 1,'Cb',1
insert into #ch select 1,'Cc',1
insert into #ch select 1,'Cd',3
insert into #ch select 1,'Cf',3
insert into #ch select 1,'Ch',1




create table #testTable (id int, name varchar(10),chid int, chname varchar(10), cpid int)

insert into #testTable 
select x.id , x.name ,isnull( y.id ,0), isnull(y.name,'') ,isnull(y.pid ,0)
from #parant as x
left outer join #ch as y
on x .id = y .pid 

SELECT t.ID, t.name , STUFF(
(SELECT ',' + s.chname
FROM #TestTable s
WHERE s.ID = t.ID
FOR XML PATH('')),1,1,'') AS CSV
FROM #TestTable AS t
GROUP BY t.ID, t.name
GO


drop table #testTable 
drop table #ch 
drop table #parant 

对于上述数据,我得到以下结果

1 PA Ca,Cb,Cc,Ch 2 PB
3 PC Cd,Cf

于 2013-08-15T14:53:02.680 回答