在MS-SQL2000中模拟窗口函数ROW_NUMBER()
2009-03-26 14:04
127 查看
原贴地址:http://www.techrss.cn/html/2009/02-06/214505.htm
ROW_NUMBER()是MS SQL Server 2005中新增窗口函数,可用来直接生成行号。如:
select ROW_NUMBER() over (order by ENo), ENo,EName
from Employee
select ROW_NUMBER() over (order by ENo), ENo,EName
from Employee
但是SQL Server 2000中是没有这个函数的,那除了迁移数据库版本外,有没有替代的解决方法呢?答案是肯定的。
有两个思路
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
总能找到不存在重复值的表达式的。
ROW_NUMBER()是MS SQL Server 2005中新增窗口函数,可用来直接生成行号。如:
select ROW_NUMBER() over (order by ENo), ENo,EName
from Employee
select ROW_NUMBER() over (order by ENo), ENo,EName
from Employee
但是SQL Server 2000中是没有这个函数的,那除了迁移数据库版本外,有没有替代的解决方法呢?答案是肯定的。
有两个思路
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
总能找到不存在重复值的表达式的。
相关文章推荐
- 在MS-SQL2000中模拟窗口函数ROW_NUMBER()
- SQL Server 2000数据库中模拟窗口函数ROW_NUMBER
- hive 中窗口函数row_number,rank,dense_ran,ntile分析函数的用法
- hive 中窗口函数row_number,rank,dense_ran,ntile分析函数的用法
- Hive窗口和分析函数[RANK()、DENSE_RANK()、ROW_NUMBER()]
- sql 排序 ROW_NUMBER() OVER 函数
- 四个排名函数(row_number、rank、dense_rank和ntile)的比较
- sql Server 05中利用ROW_NUMBER() 函数分页
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- ROW_NUMBER()函数的使用
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- oracle 中的 ROW_NUMBER() OVER() 函数
- row_number(),With rollUp,With Ctm 函数的使用
- ROW_NUMBER() OVER函数的基本用法
- ROW_NUMBER() OVER函数的基本用法
- Hive分析函数row_number() 【分组topk】
- ROW_NUMBER SQL Server 2005的LIMIT功能实现(ROW_NUMBER()排序函数)
- Mysql row number()排序函数的用法和注意
- Sql Server2005 4个排名函数: RANK(),DENSE_RANK(),ROW_NUMBER(),NTILE()
- Oracle分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法(转载)