Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.03.05;
Скачать: CL | DM;

Вниз

Не могу сохранить int64 в поле bigint   Найти похожие ветки 

 
Lbvf1   (2004-02-09 14:51) [0]

Не могу сохранить значение int64 в поле bigint


var i:int64;
....

// сохранение
q.ParamByName("p1").Value := i;
q.ExecSQL;
// записываю 1152921504606846976 (2^60)
// а там оказывается 1152921504606850000

// а чтение работает корректно
i := VarAsType(q.FieldByName("f1").AsVariant, varInt64);



записывать так вообще не получается, если значение больше 2^32
q.ParamByName("p1").Value :=
VarAsType(Variant(i), varInt64);


что делать?


 
VLAD-MAL   (2004-02-09 15:00) [1]

А какие компоненты доступа к данным? BDE не умеет, кажись... Что-то настраивать нужно...


 
Anatoly Podgoretsky ©   (2004-02-09 15:03) [2]

Чистый double 15 значащих цифр


 
ZrenBy ©   (2004-02-09 15:27) [3]

Ну не умеют TADOxxx 6-ой версии работать с bigint.
Спасибо большое Borlandy

Извратиться можно так.

var i : Int64;
j : Integer;
v : Variant;
begin
i := -1234567890987654321;
v := VarArrayCreate([0,7],varByte);

for j:=0 to 7 do v[j] := PByte( Integer(@i)+7-j )^;

ADOQuery2.Parameters.ParamByName("A").Value := 3;
ADOQuery2.Parameters.ParamByName("M").Value := v;
ADOQuery2.ExecSQL;

M - DataType = ftBytes
Size = 8


 
Lbvf1   (2004-02-09 16:48) [4]

q.ParamByName("p1").Value := inttostr(i);
- СРАБОТАЛО!



Страницы: 1 вся ветка

Текущий архив: 2004.03.05;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.015 c
3-12287
snake7
2004-02-07 10:37
2004.03.05
Provider=Microsoft.Jet.OLEDB.4.0


1-12394
Insert
2004-02-24 19:27
2004.03.05
Список файлов?


14-12520
juicenman
2004-02-12 11:36
2004.03.05
распознавание тескта


8-12455
Neznaika
2003-11-02 20:33
2004.03.05
Визуализатор для TMediaPlayer


6-12464
Незнающий
2003-12-30 19:46
2004.03.05
броадкаст датаграммы