我有一个看起来像这样的表,让我们称之为这个表B
。
id boardid schoolid subject cnt1 cnt2 cnt3 ....
=================================================================
1 20 21 f
2 20 21 r
3 20 21 w
4 20 21 m
5 20 30 r
6 20 30 w
7 20 30 m
假设计数只是整数。请注意,没有subject = f
for schoolid = 30
。同样,对于大多数学校来说,有些学校subject
并不存在。你可能有一个schoolid
刚刚r, w
或一些只是r, m, f
..
所以我想要做的是每所学校有 4 个一致的行,并且不存在的行我想要虚拟值。我想过创建一个辅助表
drop table #A
Select * into #A FROM
(
select [subject_s] = 'r', orderNo = 1
union all
select [subject_s] = 'w', orderNo = 2
union all
select [subject_s] = 'm', orderNo = 3
union all
select [subject_s] = 'f', orderNo = 4
) z
并在他们身上做一些连接,但我没有得到任何地方。我试过内连接,左外连接,交叉连接,一切。我什至尝试过制作笛卡尔积。我认为我的笛卡尔乘积搞砸了,因为我orderno
在那里,所以它在主表中每行有 16 行。实际上输入这个,我意识到如果我删除orderno
,应用笛卡尔积,然后在稍后添加 orderno,它可能会起作用,但我很想看看你们能想出什么。我难住了。
最终结果
id boardid schoolid subject cnt1 cnt2 cnt3 ....
=================================================================
1 20 21 r
2 20 21 w
3 20 21 m
4 20 21 f
5 20 30 r
6 20 30 w
7 20 30 m
7 20 30 f