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

 我来答
刺友互
高粉答主

2019-06-18 · 每个回答都超有意思的
知道答主
回答量:3979
采纳率:100%
帮助的人:67.1万
展开全部

1、用Navicat for MySQL新建一张表名为“nubers”的表。

2、表中只有一列,并插入数字1到35。

3、新建一个查询,开始测试limit的用法。输入查询语句“SELECT * FROM nubers LIMIT 10,1”并运行,可以看到结果中只显示“11”。

4、输入查询语句“SELECT * FROM nubers LIMIT 20,1”并运行,可以看到结果中只显示“21”。

5、输入查询语句“SELECT * FROM nubers LIMIT 10,3”并运行,可以看到结果中显示“11,12,13”三行数据。

6、输入查询语句“SELECT * FROM nubers LIMIT 20,3”并运行,可以看到结果中显示“21,22,23”三行数据。

7、LIMIT后的第一个参数是读取数据表中第n+1行数据,第二个参数为递增数,从n+1行开始递增,其为1则递增1行,为2则递增2行,为4则递增4行数据。

就烦条0o
2018-08-02 · 知道合伙人软件行家
就烦条0o
知道合伙人软件行家
采纳数:33315 获赞数:46487
从事多年系统运维,喜欢编写各种小程序和脚本。

向TA提问 私信TA
展开全部
解决方案:
虽然SQL Server不支持 Limit ,但是它支持 TOP
如果要查询上述结果中前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
)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
千锋教育
2018-07-29 · 做真实的自己 用良心做教育
千锋教育
千锋教育专注HTML5大前端、JavaEE、Python、人工智能、UI&UE、云计算、全栈软件测试、大数据、物联网+嵌入式、Unity游戏开发、网络安全、互联网营销、Go语言等培训教育。
向TA提问
展开全部
解决方案:
虽然SQL Server不支持 Limit ,但是它支持 TOP
如果要查询上述结果中前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
)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
己学好4
推荐于2018-04-04 · TA获得超过1.5万个赞
知道大有可为答主
回答量:1.1万
采纳率:91%
帮助的人:5054万
展开全部
解决方案:
虽然SQL Server不支持 Limit ,但是它支持 TOP
如果要查询上述结果中前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
)
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
greystar_cn
2018-07-28 · 知道合伙人软件行家
greystar_cn
知道合伙人软件行家
采纳数:16407 获赞数:17260
本人主要从事.NET C#方向的技术开发工作,具有10多年的各类架构开发工作经验。

向TA提问 私信TA
展开全部
但是,在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 @pageSize id from tablename
where id not in (
select top @offset id from tablename
)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式