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

Вниз

Экспорт данных из базы Interbase в скрипт средствами Delphi   Найти похожие ветки 

 
mvs ©   (2006-03-06 17:43) [0]

Добрый день
Хочу написать небольшую функцию экспорта данных из базы Interbase в скрипт. Пошел вначале самым простым путем
1. Получаю все таблицы
2. Экспортирую данные из очередной таблицы TableName
Сначала
ibq.sql.text := select * from tablename
Потом
ff := false;
Fieldsstr := "";
while not ibq.Eof do begin
ValuesStr := "";
for i := 0 to ibq.FieldCount - 1 do begin
if ibq.Fields[i].FieldKind <> fkData then continue;
// Простейшая функция получения значания поля, а если это блоб, то игнорировать
if not GetFieldValue(ibq.Fields[i],0,ValStr) then continue;
if not ff then begin
if Fieldsstr = "" then Fieldsstr := ibq.Fields[i].FieldName
else Fieldsstr := Fieldsstr + "," + ibq.Fields[i].FieldName;
end;
if Valuesstr = "" then Valuesstr := ValStr
else Valuesstr := Valuesstr + "," + ValStr;
end;
// конец for i
if not ff then begin
Fieldsstr := "insert into " + tablename + " (" + Fieldsstr + ")";
ff := true;
end;
Valuesstr := " values (" + Valuesstr + ")";
OutStr := OutStr + Fieldsstr + Valuesstr + ";" + CRLF;
ibq.Next;
end;
Возвращаю OutStr типа string

ПРОБЛЕМА в том, что на больших таблицах эта функция очень долгая. Наверняка есть возможность все УСКОРИТЬ. Например, в IBExpert"е экспорт идет гораздо быстрее. Очень хочется посмотреть его алгоритм или нечто подобное.


 
Fay ©   (2006-03-06 18:30) [1]

юзай TStringList



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

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

Наверх




Память: 0.47 MB
Время: 0.042 c
15-1144235817
ilifant
2006-04-05 15:16
2006.04.30
Проблема со справочной системой


2-1144753470
Eksell
2006-04-11 15:04
2006.04.30
Visual_Effects_in_Win_XP


2-1144846775
dima_kds
2006-04-12 16:59
2006.04.30
Excel


11-1125313791
DmiSb
2005-08-29 15:09
2006.04.30
Медленная обработка события OnKeyUp в EditBox


15-1144358561
Gero
2006-04-07 01:22
2006.04.30
Поклонникам Opera посвящается