Главная страница
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.017 c
1-20103
dimon1979
2003-06-24 14:39
2003.07.07
Встроенный ассемблер


3-19980
Artemij
2003-06-13 10:52
2003.07.07
DBListBox


14-20284
NVO
2003-06-19 08:00
2003.07.07
Передача данных из таблиц с Lookup полями из COM+ в приложение


11-20028
Alexander
2002-10-29 19:41
2003.07.07
После обновления до 1.56 не могу кинуть на форму KOLMHXP


3-20018
Max_
2003-06-11 13:36
2003.07.07
Экспорт TQuery результата в Paradox и Access!