Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/83.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 名称为';光标名称';不存在_Sql_Cursor - Fatal编程技术网

Sql 名称为';光标名称';不存在

Sql 名称为';光标名称';不存在,sql,cursor,Sql,Cursor,我有一个使用嵌套游标的代码。当我解析它时,SQL studio会告诉我“命令已成功完成”,但每当我执行时,我都会得到一堆重复的“名为‘cursor_stats’的游标不存在”。对于中提到的每一行cursor_stats,都会显示错误消息,然后重复多次。知道我的问题是什么吗 DECLARE @dc_grp AS VARCHAR(50) DECLARE @reqt_id AS INT DECLARE cursor_pairs CURSOR FOR SELECT DISTINCT dc.dc_gr

我有一个使用嵌套游标的代码。当我解析它时,SQL studio会告诉我“命令已成功完成”,但每当我执行时,我都会得到一堆重复的“名为‘cursor_stats’的游标不存在”。对于中提到的每一行cursor_stats,都会显示错误消息,然后重复多次。知道我的问题是什么吗

DECLARE @dc_grp AS VARCHAR(50)
DECLARE @reqt_id AS INT

DECLARE cursor_pairs CURSOR FOR
 SELECT DISTINCT dc.dc_grp, dcx.reqt_id
 FROM DC_GRP dc INNER JOIN
      DC_GRPX dcx ON dc.dc_grp = dcx.dc_grp INNER JOIN
      REQT req ON dcx.reqt_id = req.reqt_id
WHERE dc.calc_stddev = 1 AND req.v_a = 'V' AND dcx.stddev_last_update != CONVERT(datetime, Convert(int, GetDate()))
ORDER BY dc.dc_grp, dcx.reqt_id

--------------------------------------
DECLARE @vavg AS FLOAT
DECLARE @vstddev AS FLOAT

DECLARE cursor_stats CURSOR FOR
 SELECT AVG(r.[var]), STDEV(r.[var])
 FROM RESULTS r INNER JOIN
      INSTANCE i ON r.inst_id = i.inst_id
 WHERE i.dc_grp = @dc_grp AND r.reqt_id = @reqt_id AND r.[var] != 0 AND r.inst_id IN 
          (
          SELECT TOP 100 inst_id
          FROM RESULTS
          WHERE reqt_id = @reqt_id
          ORDER BY inst_id DESC
          )

---------------------------------------

OPEN cursor_pairs
   FETCH NEXT FROM cursor_pairs INTO @dc_grp, @reqt_id
   WHILE @@FETCH_STATUS = 0
   BEGIN
     OPEN cursor_stats
        FETCH NEXT FROM cursor_stats INTO @vavg, @vstddev
        WHILE @@FETCH_STATUS = 0
        BEGIN
          PRINT @dc_grp + ' ' + @reqt_id + ' ' + @vavg + ' ' + @vstddev
        FETCH NEXT FROM cursor_stats INTO @vavg, @vstddev
        END
     CLOSE cursor_stats
     DEALLOCATE cursor_stats
   FETCH NEXT FROM cursor_pairs INTO @dc_grp, @reqt_id
   END
CLOSE cursor_pairs
DEALLOCATE cursor_pairs

您不应该在循环内取消分配游标统计信息

只有在所有处理完成后才能执行此操作