我已經嘗試了多種不同的方式,但我能找到的唯一途徑,在保證方式產生所需的結果是:
declare @t table (ID int not null,Value char(1) not null,OrderNumber int null)
insert into @T(ID,Value,OrderNumber) values
(1,'A',NULL),
(2,'E',4),
(3,'C',NULL),
(4,'B',NULL),
(5,'F',2),
(6,'D',NULL)
;With Nbrs as (
select ROW_NUMBER() OVER (ORDER BY ID) as n from @t
), AvailableNbrs as (
select n,ROW_NUMBER() OVER (ORDER BY n) as rn from Nbrs where n not in (select OrderNumber from @t where OrderNumber is not null)
), RequiredOrders as (
select ID,ROW_NUMBER() OVER (ORDER BY ID) as rn from @t where OrderNumber is null
)
select
*,COALESCE(OrderNumber,an.n) as FinalOrder
from
@t t
left join
RequiredOrders ro
on
t.ID = ro.ID
left join
AvailableNbrs an
on
ro.rn = an.rn
order by COALESCE(OrderNumber,an.n)
在哪裏我們使用幾個CTE來查找當前未分配的OrderNumber
,並將這些1-1與沒有OrderNumber
的行匹配。
結果:
|--------- @t --------------| |----- RequiredOrders ---------| |----- AvailableNbrs -------------------| |- COALESCE -------|
ID Value OrderNumber ID rn n rn FinalOrder
----------- ----- ----------- ----------- -------------------- -------------------- -------------------- --------------------
1 A NULL 1 1 1 1 1
5 F 2 NULL NULL NULL NULL 2
3 C NULL 3 2 3 2 3
2 E 4 NULL NULL NULL NULL 4
4 B NULL 4 3 5 3 5
6 D NULL 6 4 6 4 6
什麼順序記錄是,如果他們有'NULL'的訂單編號? –
該記錄必須按ID列升序進行排序。 – bselvan
如果兩條記錄都說'位置2'會發生什麼?講座中討論的主題是什麼?類中涵蓋了SQL Server 2008 SQL的哪些功能? –