日期:2014-05-18  浏览次数:20621 次

sql2000的bug?
实际应用中偶然发现,@@version为8.0.194
SQL code

declare @tmp table (id1 int identity(1,1),id int,nid int,fday int,fexp nvarchar(50))
--nid为用于最后排序输出,fday为日期,先插入各天业务,再计算各天发生额与余额,再计算月发生额与余额
--最后按日期排序输出。
declare @tmp1 table (id int)
insert into @tmp (id,nid,fday,fexp)
select 1,0,1,'业务'
union all select 1,0,1,'业务' union all select 1,0,1,'业务'
union all select 1,0,2,'业务' union all select 1,0,2,'业务'
union all select 1,0,2,'业务' union all select 1,0,2,'业务'
union all select 1,0,3,'业务' union all select 1,0,3,'业务'
union all select 1,0,5,'业务' union all select 1,0,5,'业务'
union all select 1,0,5,'业务' union all select 1,0,8,'业务'
union all select 1,0,8,'业务' union all select 1,0,8,'业务'
union all select 1,0,8,'业务' union all select 1,0,9,'业务'
union all select 1,0,9,'业务' union all select 1,0,10,'业务'
union all select 1,0,10,'业务' union all select 1,0,10,'业务'
union all select 1,0,11,'业务' union all select 1,0,12,'业务'
union all select 1,0,12,'业务' union all select 1,0,12,'业务'
union all select 1,1,1,'本日发生额与余额' union all select 1,1,2,'本日发生额与余额'
union all select 1,1,3,'本日发生额与余额' union all select 1,1,5,'本日发生额与余额'
union all select 1,1,8,'本日发生额与余额' union all select 1,1,9,'本日发生额与余额'
union all select 1,1,10,'本日发生额与余额' union all select 1,1,11,'本日发生额与余额'
union all select 1,1,12,'本日发生额与余额' union all select 1,2,31,'本月发生额与余额'
insert into @tmp1 values (1)

select a.id,a.id1,count(*) nid
from @tmp a,@tmp b,@tmp1 c
where a.id=b.id and a.id=c.id and (a.fday>b.fday or a.fday=b.fday and a.nid>b.nid or a.fday=b.fday and a.nid=b.nid and a.id1>=b.id1)
group by a.id,a.id1
order by 1,3

update aa
set nid=bb.nid
from @tmp aa,
   ( select a.id,a.id1,count(*) nid
from @tmp a,@tmp b,@tmp1 c
where a.id=b.id and a.id=c.id and (a.fday>b.fday or a.fday=b.fday and a.nid>b.nid or a.fday=b.fday and a.nid=b.nid and a.id1>=b.id1)
group by a.id,a.id1) bb
where aa.id=bb.id and aa.id1=bb.id1
--update后输出结果不正确,nid不是子查询的连续整数。
select * from @tmp order by id,nid


结果
SQL code

id          id1         nid
----------- ----------- -----------
1           1           1
1           2           2
1           3           3
1           26          4
1           4           5
1           5           6
1           6           7
1           7           8
1           27          9
1           8           10
1           9           11
1           28          12
1           10          13
1           11          14
1           12          15
1           29          16
1           13          17
1           14          18
1           15          19
1           16          20
1           30          21
1           17          22
1           18          23
1           31          24
1           19          25
1           20          26
1           21          27
1           32          28
1           22          29
1           33          30
1           23          31
1           24          32
1           25          33
1           34          34
1           35          35

(35 行受影响)

(35 行受影响)

id1         id          nid         fday        fexp
----------- ----------- ----------- ----------- --------------------------------------------------
1           1           1           1           业务
2           1           2           1           业务
3           1           2           1           业务
26          1           2           1           本日发生额与余额
27          1           5           2           本日发生额与余额
4           1           5           2           业务
5           1           5           2           业务
6           1           5           2           业务
7           1           5           2           业务
8           1           10          3           业务
9           1           10          3           业务
28