Показать сообщение отдельно
  #3  
Старый 11.08.2007, 22:02
Аватар для 4kusNick
4kusNick 4kusNick вне форума
Местный
 
Регистрация: 06.09.2006
Адрес: Россия, Санкт-Петербург
Сообщения: 444
Репутация: 550
По умолчанию

Для работы с SQLite юзаю такой компонент: SQLite4Delphi

Вот пример тормозящих запросов:

Код:
function ExecDataSetSQL(DataSet: TSLDataSet; sSQL: String): Integer;
begin

  Result := 0;
  with DataSet do
  begin
    Close;
    SQL.Text := sSQL;
    Open
  end;
  DataSet.First;
  Result := DataSet.RecordCount;

end;

  //...
  // выбираем все параметры по продуктам
  ExecDataSetSQL(FSLDataSet,'SELECT * FROM catalog_products_properties WHERE ' + StringReplace(sQuery,'id','product_id',[rfIgnoreCase,rfReplaceAll]));
  NewDataSet.Close;
  NewDataSet.SQL.Clear;
  while not FSLDataSet.Eof do
  begin
    NewDataSet.SQL.Text := SQL.Text + 'INSERT INTO catalog_products_properties VALUES (' + QuotedStr(FSLDataSet.FieldByName('id').AsString) + ',' + QuotedStr(FSLDataSet.FieldByName('product_id').AsString) + ',' + QuotedStr(FSLDataSet.FieldByName('type').AsString) + ',' + QuotedStr(FSLDataSet.FieldByName('data_id').AsString) + ',' + QuotedStr(FSLDataSet.FieldByName('value').AsString) + ');';
  FSLDataSet.Next;  
  end;
  NewDataSet.Open // вот тут начинается построение БД по строке в свойстве SQL новой БД
  //...

Вот... Это часть процедуры экспорта данных из БД,
FSLDataSet - это основная БД со всеми данными,
NewDataSet - это новая БД с выбраннывми из основной БД данными

Вот вышеприведенный кусок кода работает очень медленно, причем не процессор работает, а именно HDD и размер новой БД растет примерно так: 1 КБ\СЕК...
А размер в итоге получается 1.3 МБ, представьте, сколько времени идет этот экспорт =)
Вот, пробовал NewDataSet.Open делать каждый раз при каждой итерации цикла, то же самое =(
Спасибо =)
__________________
THE CRACKER IS OUT THERE
Ответить с цитированием