日期:2014-05-17 浏览次数:20546 次
主表 (PID为主键)
PID Data...
1 X
2 X
3 X
...
副表 (ID为主键,PID为主表的主键)
ID PID Data...
1 1 A
2 1 B
3 1 C
4 2 D
5 2 E
6 3 F
7 3 G
...
临时表 (PID就是主表中的PID)
PID Pos
1 2
2 2
3 1
PID Pos ID Data...
1 2 2 B (因为PID为1的数据有3条,对应数据A,B,C,而pos=2就是B)
2 2 5 E (因为PID为2的数据有2条,对应数据D,E,而pos=2就是E)
3 1 7 F (因为PID为3的数据有2条,对应数据F,G,而pos=1就是F)
create table 副表
(ID int, PID int, Data varchar(5))
insert into 副表
select 1, 1, 'A' union all
select 2, 1, 'B' union all
select 3, 1, 'C' union all
select 4, 2, 'D' union all
select 5, 2, 'E' union all
select 6, 3, 'F' union all
select 7, 3, 'G'
create table 临时表
(PID int, Pos int)
insert into 临时表
select 1, 2 union all
select 2, 2 union all
select 3, 1
select t.PID,t.Pos,f.ID,f.Data
from (select ID,PID,Data,
row_number() over(partition by PID order by ID) 'rn' from 副表) f
inner join 临时表 t on f.PID=t.PID and f.rn=t.Pos
/*
PID Pos ID Data
----------- ----------- ----------- -----
1 2 2 B
2 2 5 E
3 1 6 F
(3 row(s) affected)
*/