Модераторы: Akina
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Хранимая процедура неправильно отрабатывает 
:(
    Опции темы
Leklerk
Дата 19.3.2012, 19:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 200
Регистрация: 31.7.2009
Где: Санкт-Петербург

Репутация: нет
Всего: нет



Добрый день! Работаю в SQL Server 2005, запускаю хранимую процедуру, о она вставляет последнюю запись курсора 2 раза вместо одного. Подскажите, что не так? 
Код

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
 
ALTER procedure [dbo].[Вставка_Табель_малая]
 
AS    
 
DECLARE @Компьютер  VARCHAR(30)
 
DECLARE КурсорПользователи CURSOR
FOR SELECT Компьютер FROM Пользователи
 
OPEN КурсорПользователи
 
WHILE @@Fetch_Status = 0 BEGIN
    FETCH КурсорПользователи INTO @Компьютер
    INSERT INTO Табель_малая VALUES(
        @Компьютер,
        Convert(VARCHAR(30),Getdate(),104),
        '',
        '',
        1)
END

PM MAIL ICQ   Вверх
Zloxa
Дата 19.3.2012, 19:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 10
Всего: 161



@@Fetch_Status возвращает статус последнего фетча. Проверяя его до вашего фетча, вы проверяете статус какого-то чужого фетча. На втором витке цикла вы уже проверяете статус своего фетча.

добавьте 
Код

FETCH КурсорПользователи INTO @Компьютер

перед началом цикла.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Leklerk
Дата 20.3.2012, 12:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 200
Регистрация: 31.7.2009
Где: Санкт-Петербург

Репутация: нет
Всего: нет



Нет, так не работает. Работает, если кроме того поставить этот код перед END (вместо перед INSERT).

Это сообщение отредактировал(а) Leklerk - 20.3.2012, 12:38
PM MAIL ICQ   Вверх
Zloxa
Дата 20.3.2012, 14:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 10
Всего: 161



Цитата(Leklerk @  20.3.2012,  13:32 Найти цитируемый пост)
Нет, так не работает. 

Да, еще исходный фетч надо переместить после инсерта.
Цитата(Leklerk @  20.3.2012,  13:32 Найти цитируемый пост)
Работает, если кроме того поставить этот код перед END (вместо перед INSERT).

Попробуйте как это будет работать в случае, если курсор не вернет ни одного значения.
Или я вас не так понял, вы так и сделали?
Один фетч перед while, один фетч перед end.

Это сообщение отредактировал(а) Zloxa - 20.3.2012, 16:22


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Leklerk
Дата 20.3.2012, 16:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 200
Регистрация: 31.7.2009
Где: Санкт-Петербург

Репутация: нет
Всего: нет



Да, именно так. Но я нашел другое решение (точнее, мне помогли), без курсоров:
Код

ALTER procedure [dbo].[Вставка_Табель_малая]
AS    

    INSERT INTO Табель_малая 
    SELECT Компьютер, Convert(VARCHAR(30),Getdate(),104), '', '', 1
    FROM Пользователи

PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "MS SQL"
Akina

Akina

Запрещается!

Публиковать ссылки и обсуждать взлом чего бы то ни было.

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы составления неспецифических запросов рассматриваются здесь
  • Используйте теги [code=sql][/code] для подсветки кода. Используйтe чекбокс "транслит" (возле кнопок кодов) если у Вас нет русских шрифтов.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, Akina.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MS SQL Server | Следующая тема »


 




[ Время генерации скрипта: 0.0694 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.