Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вызов хранимой процедуры через TADODataSet, Из-за чего генеритcя исключение 
:(
    Опции темы
SATYR
Дата 6.7.2005, 16:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



TADODataSet *ADODS;

когда хранимая процедура "SEL_CORD5" имела два параметра все работало просто в лёт.
Код

void __fastcall TRepMast::BitBtn1Click(TObject *Sender){
  ADODS->CommandText="EXEC SEL_CORD5 '"+LowD->Text+"','"+HiD->Text+"'";
  ADODS->Open();



как только я ее модифицировал и добавил еще парочку
Код

void __fastcall TRepMast::BitBtn1Click(TObject *Sender){

  ADODS->CommandText="EXEC SEL_CORD5 '"+LowD->Text+"','"+HiD->Text+"','"+SetN->VirMarkList()+"','"+SetN->IPMarkList()+"'";
  ADODS->Open();


то при выполнении начало вылетать следующее исключение "Multiple-step OLE DB operation generated errors. Check each OLE DB status value, if available. No work was done."

Подскажите вчем может быть причина?
PM MAIL   Вверх
_hunter
Дата 6.7.2005, 16:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 8564
Регистрация: 24.6.2003
Где: Europe::Ukraine:: Kiev

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



толи в параметрах ошибся толи процедура кривая
для начала вызовибез всяких внешних параметров:
ADODS->CommandText="EXEC SEL_CORD5 ...";
посмотри что будет


--------------------
Tempora mutantur, et nos mutamur in illis...
PM ICQ   Вверх
MaximNR
Дата 6.7.2005, 17:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



возможно какойнить триггер висит и он срабатывает уже после выполнения процедуры и воздействует на таблицу, возвращаемую процедурой?
PM   Вверх
SATYR
Дата 6.7.2005, 17:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Тригера не висит эт точно.
В SQL Analyzer тоже исправно работает с тестовыми параметрами
PM MAIL   Вверх
_hunter
Дата 6.7.2005, 17:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 8564
Регистрация: 24.6.2003
Где: Europe::Ukraine:: Kiev

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



а в коде?



--------------------
Tempora mutantur, et nos mutamur in illis...
PM ICQ   Вверх
MaximNR
Дата 6.7.2005, 17:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



ну в общем, сообщение об ошибке можно перевести так, что
"многошаговая операция вызвала ошибку. ПРоверьте каждый шаг"

т.е. возможно, например, что процедура получила данные и вызвала какие-то изменения в чем-то, а это что-то при отображении содержит еще старые данные(допустим в каких-то контролах и т.п.).

можно попробовать задисэйблить все контролы вначале операции, а потом их обновить и заенеблить.
PM   Вверх
SATYR
Дата 7.7.2005, 08:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Народ ещё вопрос не потеме. Случайно не подскажете в MS SQL есть какой-нить пошаговый отладчик кода?
PM MAIL   Вверх
_hunter
Дата 7.7.2005, 10:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 8564
Регистрация: 24.6.2003
Где: Europe::Ukraine:: Kiev

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



в разделе по SQL и спроси...


--------------------
Tempora mutantur, et nos mutamur in illis...
PM ICQ   Вверх
SATYR
Дата 7.7.2005, 10:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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




Нашел в чем проблема.)
В моем случае хранимка вообще не затрагивает ничего подобного контролам и не вносит никаких изменений ни куда только возвращает выбранный ряд.

Если кому интересно:
Похоже что здесь роль играет какого типа курсор испрользуется в TADODataSet. Если CyrsorLocation = clUseClient то все ок и всё работает если CyrsorLocation =clUseServer то генерится выше сказанное искл. Если не поможет то можно поменять CyrsorType. Либо комбонации этих двух св-в.

Определено методом тыка )

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++ Builder"
Rrader

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

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по С++ Builder обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Настоятельно рекомендуем заглянуть в DRKB (Delphi Russian Knowledge Base) - крупнейший в рунете сборник материалов по Дельфи


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

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


 




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


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

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