首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >光标进入无限循环

光标进入无限循环
EN

Stack Overflow用户
提问于 2013-06-04 14:38:17
回答 2查看 330关注 0票数 1
代码语言:javascript
复制
DECLARE  AssigChart CURSOR FOR SELECT  vad_id_no, drv_id_no, vad_st_dt, vad_st_tm, vad_fn_dt, vad_fn_tm FROM lu02vad WHERE lTachoSmartCardID = @tachoSmartCardID

    OPEN AssigChart FETCH NEXT FROM AssigChart INTO @ChartID, @drvid, @dStartTime, @lStartTime, @dEndTime, @lEndTime
    WHILE (@@FETCH_STATUS <> -1)
    BEGIN


<------------------some processing ---------------------->>>>>>>>


FETCH NEXT FROM AssigChart 
         INTO @ChartID, @drvid, @dStartTime, @lStartTime, @dEndTime, @lEndTime
    END
    CLOSE AssigChart
    DEALLOCATE AssigChart
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-04 14:46:12

@@FETCH_Status返回以下值....

代码语言:javascript
复制
0 The FETCH statement was successful.
-1 The FETCH statement failed or the row was beyond the result set.
-2 The row fetched is missing.

所以对于不成功,它可以返回-1和-2任何人,所以你可以像这样检查它……

代码语言:javascript
复制
while @@FETCH_STATUS=0

代码语言:javascript
复制
while @@FETCH_STATUS<>-1 and @@FETCH_STATUS<>-2
票数 1
EN

Stack Overflow用户

发布于 2013-06-04 15:27:26

试试这个-

代码语言:javascript
复制
DECLARE AssigChart CURSOR READ_ONLY LOCAL FAST_FORWARD FOR 
    SELECT vad_id_no, drv_id_no, vad_st_dt, vad_st_tm, vad_fn_dt, vad_fn_tm 
    FROM lu02vad 
    WHERE lTachoSmartCardID = @tachoSmartCardID

OPEN AssigChart 

FETCH NEXT FROM AssigChart INTO           
          @ChartID
        , @drvid
        , @dStartTime
        , @lStartTime
        , @dEndTime
        , @lEndTime

WHILE @@FETCH_STATUS = 0 BEGIN

    -- your statements

    FETCH NEXT FROM AssigChart INTO 
          @ChartID
        , @drvid
        , @dStartTime
        , @lStartTime
        , @dEndTime
        , @lEndTime

END

CLOSE AssigChart
DEALLOCATE AssigChart
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16911293

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档