如何在SQL Server中实现 Limit m,n 的功能_MySQL

WBOY
풀어 주다: 2016-06-01 13:24:40
원래의
839명이 탐색했습니다.

bitsCN.com 在MySQL中,可以用 Limit 来查询第 m 列到第 n 列的记录,例如:

select * from tablename limit m, n

但是,在SQL Server中,不支持 Limit 语句。怎么办呢?
解决方案:
虽然SQL Server不支持 Limit ,但是它支持 TOP。
我们以SQL Server 2005为例,就以它自带的示范数据库 AdventureWorks 作为测试数据:

select id from tablename

如果要查询上述结果中前6条记录,则相应的SQL语句是:

select top 6 id from tablename

如果要查询上述结果中第 7 条到第 9 条记录,则相应的SQL语句是:

select top 3 id from tablename
where id not in (
  select top 6 id from tablename
)


select top (n-m+1) id from tablename
where id not in (
  select top m-1 id from tablename
)


select top @pageSize id from tablename
where id not in (
  select top @offset id from tablename
)

bitsCN.com

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿