我有两个表,TBL_PARENT (parentID, ParentName) 和 TBL_CHILDREN (ParentID,Child_Name) 一个 Parent 可以有 0 到多个孩子
我想要的是一个查询,让我在每个父母的单行中给我一个父母和他们的孩子的列表。
例如
Parent1 John,Mary
Parent2 jane,steve,jana
并且行数是父母的总数
我有两个表,TBL_PARENT (parentID, ParentName) 和 TBL_CHILDREN (ParentID,Child_Name) 一个 Parent 可以有 0 到多个孩子
我想要的是一个查询,让我在每个父母的单行中给我一个父母和他们的孩子的列表。
例如
Parent1 John,Mary
Parent2 jane,steve,jana
并且行数是父母的总数
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,以便您可以显示每个父母的所有孩子。
试试这个查询:我创建了 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