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

Вниз

Заполнение таблицы(TADOTable) информацие из потока(TADOQuery)   Найти похожие ветки 

 
tramp   (2003-06-11 17:22) [0]

В BDE есть компонент TBathMove перемещающий информацию из одной таблицы (или потока на выходе TQuery) в другую. Как сделать это в через ADO? Добавлени по сторокам не рассаматривается. Имеется в виду что-то более быстое и элегантное :)


 
Shaman ©   (2003-06-11 17:40) [1]

Думаю, кроме как по строкам перегонять, ничего и не придумаешь (TBathMove тоже так поступает). Только передавать значения нужно без использования вариантных преобразований, тогда код будет быстро работать. Ниже приведен кусок из процедуры, делающий нечто подобное.


var
i: Integer;
j: Integer;
Q: TSQLQuery;
aDS: TClientDataSet;
F: TField;
P: Pointer;
...
j := aDS.DataSize;
GetMem(P, j);
try

while not Q.Eof do
begin
aDS.Append;
for i := 0 to Q.FieldCount - 1 do
if Q.Fields[i].GetData(P, True) then aDS.Fields[i].SetData(P, True);
aDS.Post;
Q.Next;
end;
Q.Active := False;

finally
if P <> nil then FreeMem(P);
end;

...


З.Ы. Поля двух таблиц должны быть строго идентичными


 
tramp   (2003-06-14 12:31) [2]

Имелось в виду, что Q:TADOQuery? Спасибо:-)



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

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

Наверх




Память: 0.47 MB
Время: 0.011 c
1-20140
off
2003-06-25 08:31
2003.07.07
Перетаскиваем форму.


1-20116
sach
2003-06-24 19:02
2003.07.07
непосредственный доступ к памяти


14-20223
Пубертанец
2003-06-19 11:40
2003.07.07
Как в прикладухе на время защитить/заблокировать файл от записи?


7-20317
Sliski Slimak
2003-04-23 16:34
2003.07.07
FindFirst, FindNext


1-20111
McSimm2
2003-06-23 16:05
2003.07.07
Очистка StringGrid