Форум: "Основная";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.08;
Скачать: [xml.tar.bz2];




Вниз

Ошибка Invalid Variant Operation ! 


sudiv   (2002-03-26 08:54) [0]

Мастера,
при добавлении записи в таблицу методом
Table.InsertRecord([ComboBox2.Text,
ComboBox1.Text,
StrToFloat(Edit2.Text),
ComboBox.Text,
StrToFloat(Edit3.Text)]);
возникает ошибка
Invalid Variant Operation.
Все контролы корректно заполнены.
Может знает кто в чем дело.
Сама среда не показывает ошибку на этом месте, при отладке вылетает именно на этом методе.



Johnmen   (2002-03-26 10:33) [1]

Ошибку вызывает StrToFloat(Edit2.Text) или StrToFloat(Edit3.Text)



sudiv   (2002-03-26 13:36) [2]

Да, большое спасибо за ответ, но он неверен.
Как я писал, все контролы (и эдиты) заполнены корректно => д.б. корректны и их преобразования.

Проблема оказывается несколько в другом:
В таблице есть вычисляемые поля, они соответственно, вычисляются
в OnCalcFields, т.е.
procedure TForm1.TableCalcFields(DataSet: TDataSet);
begin

end;

Прога была написана в D4, нормально компилилась и работала в D5 c таким OnCalc"ом
procedure TForm1.TableCalcFields(DataSet: TDataSet);
begin
DataSet["SUMM"] := DataSet["COUNT"] * DataSet["PRICE"]
end;

а вот в D6 эта конструкция не работает, выдает сабж,
переделал на
procedure TForm1.TableCalcFields(DataSet: TDataSet);
begin
TableSUMM.Value := TableСOUNT.Value * TablePRICE.Value;
end;
TableSUMM : TFloatField; { calculated }
TableCOUNT, TablePRICE : TFloatField;
Стало работать.
Странно все это, но факт.




Johnmen   (2002-03-26 14:00) [3]

А еще лучше
...
TableSUMM.AsFloat:=TableСOUNT.AsFloat*TablePRICE.AsFloat;
...
И это не странно, а вполне объяснимо :
DataSet["COUNT"], DataSet["PRICE"] - это Variant, который не мог преобразоваться к веществ.типу,
или DataSet["SUMM"]:=... вещ.тип не преобр. к Variant...




Форум: "Основная";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.08;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.038 c
1-22611           DimaP                 2002-03-25 19:28  2002.04.08  
Hint


14-22828          VID                   2002-02-27 23:42  2002.04.08  
Interbase.Часть 2.


14-22811          Miwa                  2002-02-26 18:29  2002.04.08  
undelete/unerase


14-22846          Olgerd                2002-02-26 03:35  2002.04.08  
А здесь вы найдете архивы старых форумов


1-22613           LiNkS                 2002-03-27 16:06  2002.04.08  
StringReplace