|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
||||
|
||||
Скорость выполнения запросов в SQLite
Здравствуйте!
Вопрос такой: Можно ли как-то увеличить скорость выполнения запросов в SQLite? Сейчас у меня делается так: 1. Создается длинная строка запрососв (около 50000). 2. Строка пихается в SQLite Пробовал пихать в SQLite не всю строку, а позапросно, но скорость такая же. Причем, процессор вообще не загружается, работает только HDD, и размер БД растет очень медленно по мере наполнения ее при помощи запросов INSERT (в строке только такие запросы). THE CRACKER IS OUT THERE |
#2
|
||||
|
||||
Показал бы часть запросов. А то немного не ясно.
|
#3
|
||||
|
||||
Для работы с 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 Последний раз редактировалось 4kusNick, 11.08.2007 в 22:07. |
#4
|
||||
|
||||
Как я понял ты добавляешь "много чего" в одну таблицу основываясь на данных из другой таблицы. Это дело нужно оптимизировать. Есть (ну по крайней мере мне известно) 2 варианта как это сделать.
1. Код:
INSERT INTO Table2 (Field1, Field2, Field3) SELECT FieldA as Field1, FieldB as Field2, FieldC as Field3 FROM Table1 WHERE Field1 = 'Some' Код:
INSERT INTO Table2 (Field1, Field2, Field3) SELECT ('Text1' as Field1,'Text2' as Field2, 'Text3' as Field3) UNION SELECT ('Text4','Text5', 'Text6') UNION SELECT ('Text7','Text8', 'Text9') ... |