select top 10 *
from UserInfo
where UserId in
(
select top 20 UserId
from UserInfo
)
order by UserId desc
第二种写法:
select top 10 * from UserInfo where UserId not in (select top 10 UserId from UserInfo )
第三种写法:
select top 10 * from UserInfo where UserId>
(select max(UserId) from (select top10 UserId from UserInfo order by UserId) a)
第四种写法(只可在Sqlserver 2005中):
select * from (select Row_Number() over (Order by UserId) as RowId ,* from UserInfo) U
where U.RowId between 10 and 20
Sqlserver 中其实还有另外几种写法,不一一写出。四种方法中,后两种的写法要比前两种写法效率要高些,但第四种只能写在SqlServer 2005中。
查出的来结果不是21条,而是9条。可以这样理解:rownum 为9后的记录的 rownum为10,因条件为 !=10,所以去掉,其后记录补上,rownum又是10,也去掉,一直这样下去,最后的结果只有9条了。
如果把后面的条件改为 where rownum>1 时,会发现查不到一条数据,如果是where rownum>0 或是where rownum>=1时则可以查询到所有的数据。原因很简单:因为 rownum 是在查询到的结果集后加上去的,它总是从1开始。
between 1 and 20 或者 between 0 and 20 能查到结果,而用 between 2 and 20 却得不到结果,原因同上一样,因为 rownum 总是从 1 开始。
所以要实现取UserInfo表其中的第11至第20条记录,可以这样写:
select * from
(select rownum as rn,t.* from userinfo t where rownum >0)
where rn between 10 and 20 查询结果: