SQL Server 2000数据库中模拟窗口函数ROW_NUMBER

1、使用临时表.
如果是在存储过程中,这是一个不错的选择.
创建一个临时表,其中除了需要的查询结果外,还一个记数列.查询结果放入临时表后(一般情况下可直接使用Insert into语句),用代码进行记数,更新记数列的值.
在记数列数值的生成方法上,还有一个改进的办法是直接将该列定义为自增长字段.这样“记数”的代码也省掉了.

2、采用自连接.
如果是在代码中,不便于使用临时表,可以采用此方法.比如执行一个查询统计,需要一个替代的SQL语句.
这个方法实际上是通过表的自连接给结果行“分等级”的思路来实现的.
语句如下:
select count(*),e1.ENo, e1.EName 
from Employee e1 
inner join Employee e2 on e1.ENo >= e2.ENo 
group by e1.ENo, e1.EName 
order by 1 
select count(*),e1.ENo, e1.EName
from Employee e1
inner join Employee e2 on e1.ENo >= e2.ENo
group by e1.ENo, e1.EName
order by 1 

或者把join条件放到where子句中:
select count(*),e1.ENo, e1.EName 
from Employee e1, Employee e2, 
where e1.ENo >= e2.ENo 
group by e1.ENo, e1.EName 
order by 1 
select count(*),e1.ENo, e1.EName
from Employee e1, Employee e2, 
where e1.ENo >= e2.ENo
group by e1.ENo, e1.EName
order by 1 

如果ENo字段值不重复,还可以这样写:
select (select count(*) from Employee e2 where e1.ENo >= e2.ENo), e1.ENo, e1.EName 
from Employee e1 
order by 1 
select (select count(*) from Employee e2 where e1.ENo >= e2.ENo), e1.ENo, e1.EName
from Employee e1
order by 1 

如果ENo字段值有重复的情况,要使用 一种写法可以将where条件变通一下,如:
where e1.ENo e1.EName >= e2.ENo e2.EName
总能找到不存在重复值的表达式的.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值