Главная страница
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.031 c
6-1100943955
Неизвестный
2004-11-20 12:45
2005.02.06
Проблема с отправкой писем


1-1106317212
BFG9k
2005-01-21 17:20
2005.02.06
Событие изменения ширины колонки в TStringGrid


14-1105702737
DimaK
2005-01-14 14:38
2005.02.06
BDE и профили пользователей в XP


14-1105861550
Константинов
2005-01-16 10:45
2005.02.06
VMWare


3-1104832769
Roter
2005-01-04 12:59
2005.02.06
Проблема вычитки identity полей из БД