Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: СУБД и Delphi/Lazarus

  Все выпуски  

RusFAQ.ru: СУБД и Delphi


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Архипов Александр Леонидович
Статус: Практикант
Рейтинг: 25
∙ повысить рейтинг >>
Лукьяненко Алексей Валериевич
Статус: Студент
Рейтинг: 25
∙ повысить рейтинг >>
Шичко Игорь
Статус: Практикант
Рейтинг: 20
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / СУБД и Delphi

Выпуск № 528
от 08.02.2009, 18:05

Администратор:Gh0stik
В рассылке:Подписчиков: 275, Экспертов: 17
В номере:Вопросов: 1, Ответов: 1

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 159517: Здравствуйте. В базе данных одна из таблиц (ReceivedDocument) имеет три внешних ключа, связывающих её с двумя другими таблицами (DocumentType, Organization). В Delphi для работы с таблицами используются компоненты IBDataSet. В св...


Вопрос № 159.517
Здравствуйте.

В базе данных одна из таблиц (ReceivedDocument) имеет три внешних ключа,

связывающих её с двумя другими таблицами (DocumentType, Organization).
В Delphi для работы с таблицами используются компоненты IBDataSet.
В свойстве InsertSQL IBDataSet'а, связанного с таблицей ReceivedDocument

вызывается хранимая процедура, добавляющая в таблицу новую запись.

Проблема в следующем: при попытке добавить запись в таблицу ReceivedDocument

выдаётся сообщение:

"validation error for column NUMDOCTYPE, value "*** null ***"".

NUMDOCTYPE - внешний ключ для связи с таблицей DocumentType.

При этом в таблице есть два внешних ключа, связывающих её с таблицей Organization - сдесь всё нормально.

Посмотрел SQL монитором что на самом деле передаётся на сервер - оказалось, что процедура вставки не вызывается, исключение возникает раньше.

При тестировании процедуры в IBExpert записи нормально добавляются - значит ошибка где-то в приложении. Вопрос: где её следует искать?
Отправлен: 03.02.2009, 18:04
Вопрос задал: Hells (статус: Посетитель)
Всего ответов: 1
Мини-форум вопроса >>> (сообщений: 0)

Отвечает: Del
Здравствуйте, Hells!

Представить код
1. Процедуры в IB
2. Код добавления записи на Delphi

Сами понимаете - телепаты в отпуске.

Я бы на вашем месте поставил бы break на нажатие, к примеру, кнопки "Занести" и проверил бы все значения полей.
Еще можно так (телепаты в отпуске, начинаем отгадывать):

procedure Form1.btnAddRecordClick(Sender: TObject);
var X: Integer;
S: string;
begin
S := '';
for X := 0 to IBDataSet1.Fields.Count-1 do begin
S := S + IBDataSet1.Fields[X].FieldName + ' = ';
if IBDataSet1.Fields[X].AsVariant = null then S := S + 'null'
else S := S + IBDataSet1.Fields[X].AsString;
S := S + #13#10;
end;
ShowMessage(S);
end;

Но лучше оттрасировать самостоятельно. Если не получится - пишите в почту, попробую помочь.
---------
Только массовые расстрелы спасут Родину!
Ответ отправил: Del (статус: 3-й класс)
Ответ отправлен: 03.02.2009, 22:10

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 242831 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное