sql如何使用游标查询指定行记录

sql使用游标可以查询第N条到第M条记录吗?怎么查?... sql使用游标可以查询第N条到第M条记录吗?怎么查? 展开
 我来答
方清海
2010-06-02 · TA获得超过315个赞
知道小有建树答主
回答量:875
采纳率:0%
帮助的人:383万
展开全部
可以
不过不用游标也可以

select * from (select *,row_number() over(order by 排序列) as rownum from table) a
where rownum>=n and rownum<=m
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
骑梼杌的小哪吒
2010-06-02 · TA获得超过625个赞
知道小有建树答主
回答量:385
采纳率:100%
帮助的人:155万
展开全部
--用游标
DECLARE @COLUMN1 VARCHAR(10)
DECLARE @LineNum INT
SET @LineNum = 1
DECLARE CUR_TEST CURSOR FOR
SELECT 语句

OPEN CUR_TEST

FETCH NEXT FROM CUR_TEST INTO @COLUMN1,...

WHILE @@FETCH_STATUS = 0
BEGIN
IF (@LineNum >= N and @LineNum <= M)
BEGIN
SELECT @COLUMN1,...
END
SET @LineNum = @LineNum + 1
END

CLOSE CUR_TEST
DEALLOCATE CUR_TEST

--用双TOP直接取出,从前M条倒序取出前(M-N)条,等同于取出了N到M之间的
SELECT TOP (M-N) * FROM (SELECT TOP M * FROM 表名 WHERE 语句 ORDER BY COLUMNname DESC)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
roy_88
推荐于2018-03-29 · TA获得超过3696个赞
知道大有可为答主
回答量:2914
采纳率:100%
帮助的人:2734万
展开全部
SQL Server 游标这样用

DECLARE @N INT,@M INT
SELECT @N=5,@M=10
DECLARE Cur1 SCROLL CURSOR FOR
SELECT * FROM sysobjects
OPEN Cur1
FETCH ABSOLUTE 5 FROM Cur1
DECLARE @i INT
SET @i=1
WHILE @@FETCH_STATUS=0
BEGIN
SET @i=@i+1
IF @i<=@M-@N+1
FETCH NEXT FROM Cur1
ELSE
GOTO Roy
END
Roy:
CLOSE Cur1
DEALLOCATE Cur1
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
shutao917
2010-06-02 · TA获得超过1213个赞
知道大有可为答主
回答量:2199
采纳率:0%
帮助的人:3137万
展开全部
当然可以,但如果想查第N条到第M条记录会有很多比游标更方便快速的方法,具体的可Hi我谈谈
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式