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

Вниз

GetCurrentRecord(PChar), обратное преобразование   Найти похожие ветки 

 
XAdmin   (2005-01-09 10:01) [0]

Есть данные в виде Pchar полученные с помощью метода GetCurrentRecord (возвращает запись целиком).
var
 P: PChar;
begin
 GetMem(P, FIBDataSet.RecordSize);
 FIBDataSet.GetCurrentRecord(P)

Как из переменной P выделить конкретные поля?


 
sniknik ©   (2005-01-09 12:28) [1]

элементарно... расчитываеш по размерам полей до записи начало поля и копируеш кусок равный размеру поля, преобразовываеш к нужному типу (если есть нужда)... обламываешся с полями типа текст, блов, и  аналогичными. ;о)) бо нет в них данных, в рекордсете.
копируеш (выделяеш) так move(P[расчитаная точка начала записи], буфер приемник, размер записи)
в общем все так же как и сам копмонент делает.

чем не подходит fieldbyname(?)/fields[?] ???


 
DSKalugin ©   (2005-01-10 15:14) [2]

Все гениальное просто

var Nafiga: Variant;
  fi,fc:Byte;
begin
fc:=Table666.FieldCount-1;
//объявляю переменную для хранения значений полей записи
Nafiga:=VarArrayCreate([0,fc], varVariant);
//копирую запись в переменную
for fi:=0 to fc do Nafiga[fi]:=Table666.fields[fi].Value;
//обратное действие
Table666.Insert/Edit;
for fi:=0 to fc do Table666.fields[fi].Value:=Nafiga[fi];
Table666.Post;
end;



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

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

Наверх




Память: 0.47 MB
Время: 0.033 c
1-1106146857
BaDeVlad
2005-01-19 18:00
2005.02.06
Как поменять текущий Screen-Saver в системе?


3-1104347007
Apophis
2004-12-29 22:03
2005.02.06
Почему не работает SQL запрос?


14-1106152158
OneFragLeft
2005-01-19 19:29
2005.02.06
Текст под мышом в RichEdit, например.


14-1105981791
www.Vlad.uk
2005-01-17 20:09
2005.02.06
Скоро на нашей планете всё время будет ночь!


14-1105670756
Думкин
2005-01-14 05:45
2005.02.06
С Днем Рождения! 14 января