Курсор пока цикл никогда не останавливается. что не так в этом коде?

/*CREATE TABLE m_b (code VARCHAR(10),itemcount INT,type VARCHAR(30),amount  MONEY)        
insert into m_b values ('B001',1,'Dell',10)
insert into m_b values ('B001',1,'Dell',10)
insert into m_b values ('B001',1,'Apple',10)
insert into m_b values ('B001',2,'Apple',20)
insert into m_b values ('B001',2,'Apple',20)
insert into m_b values ('B114',1,'Apple',30.5)
insert into m_b values ('B114',1,'Apple',10) */

 --SELECT * INTO #temp FROM m_c  WHERE 1=2

DECLARE cur_test CURSOR 
 FOR SELECT Jobid,start,end_date,dayrate FROM m_c 

 go

DECLARE @Jobid INT
DECLARE @start DATE,@end_date DATE
DECLARE @dayrate INT 

OPEN cur_test
FETCH cur_test INTO @Jobid,@start,@end_date,@dayrate

--BEGIN 
DECLARE @jan INT

SET @jan=0

WHILE (@@sqlstatus != 2)

BEGIN

  IF month(@start)=1 
  BEGIN

    SELECT @jan= @jan + datediff(dd,'2013-01-31',@start)
    -- testing purpose
    INSERT INTO #temp VALUES (@jan,@start,@end_date,56)
  END 

  IF month(@end_date)=1 
  BEGIN

    SELECT @jan= @jan + datediff(dd,'2013-01-31',@end_date)
    -- testing purpose
    INSERT INTO #temp VALUES (@jan,@start,@end_date,57)

  END 

  FETCH cur_test INTO @Jobid,@start,@end_date,@dayrate

END


SELECT @jan

WAITFOR  delay '00:00:10'

CLOSE  cur_test

DEALLOCATE CURSOR cur_test
--END 

SELECT * FROM #temp

--TRUNCATE TABLE #temp

2 ответа

Вам нужно будет проверить состояние выборки с помощью этого:

WHILE @@ FETCH_STATUS = 0

Базирование вашего курсора на значении данных будет означать бесконечный цикл, если выходное значение никогда не будет достигнуто.

Я не уверен, почему вы никогда не останавливаетесь, но я всегда использую условие ниже

while @@sqlstatus = 0

так что попробуйте использовать его вместо

WHILE (@@sqlstatus != 2)
Другие вопросы по тегам