Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 28.02.2013, 12:53
mind.beggar mind.beggar вне форума
Прохожий
 
Регистрация: 25.01.2013
Сообщения: 6
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Invalid variant type conversion

Код:
     DM1.Qtemp.Close;
     DM1.Qtemp.SQL.Clear;
     DM1.Qtemp.SQL.Add('insert into sb_dok_el(INSTRKOD, DOCNUM, DOKDATE, KLADOVSCHIK, DOK_ID, SKLKOD, OPTYPE_ID, ID_ROOTDOC)');
     DM1.Qtemp.SQL.Add('values (:aINSTRKOD, :aDOCNUM, :aDOKDATE, :aKLADOVSCHIK, :aDOK_ID, :aSKLKOD, :aOPTYPE_ID, :aID_ROOTDOC)');
     with DM1.Qtemp.ParamByName('aINSTRKOD') do
       begin
         ParamType := ptInput;
         DataType := ftInteger;
         Value := DM1.qSklad.FieldByName('INSTRKOD').Text
       end;
     with DM1.Qtemp.ParamByName('aDOCNUM') do
       begin
         ParamType := ptInput;
         DataType := ftString;
         Value := eNum.Text;
       end;
     with DM1.Qtemp.ParamByName('aDOKDATE') do
       begin
         ParamType := ptInput;
         DataType := ftDate;
         Value := eDOKDATE.Value;
       end;
     with DM1.Qtemp.ParamByName('aKLADOVSCHIK') do
       begin
         ParamType := ptInput;
         DataType := ftString;
         Value := eKLADOVSCHIK.Text;
       end;
     with DM1.Qtemp.ParamByName('aDOK_ID') do
       begin
         ParamType := ptInput;
         DataType := ftInteger;
         Value := sb_dok_id;
       end;
     with DM1.Qtemp.ParamByName('aSKLKOD') do
       begin
         ParamType := ptInput;
         DataType := ftInteger;
         Value := skl_kod;
       end;
     with DM1.Qtemp.ParamByName('aOPTYPE_ID') do
       begin
         ParamType := ptInput;
         DataType := ftInteger;
         Value := 92;
       end;
     with DM1.Qtemp.ParamByName('aID_ROOTDOC') do
       begin
         ParamType := ptInput;
         DataType := ftInteger;
         Value := rootdoc_id;
       end;
     DM1.Qtemp.ExecSQL;

На ExecSQL валится ошибка "Invalid variant type conversion".
Как ее вылечить?
Ответить с цитированием
  #2  
Старый 28.02.2013, 13:01
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Value у параметров - variant, попробуй использовать ф-ю VarAsType при присвоении значения параметра.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 04:07.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025