|
|
|
тормозит запрос (DELETE)
|
|||
|---|---|---|---|
|
#18+
Поделитесь советами. Имеется таблица содержащая порядка 100 000 записей. необходимо последовательно выполнить 2 запроса (Delete и Update). Таким образом под условия запросов подпадает порядка 10 000 записей. является ли нормальным общее время выполнения этих запросов около 4 минуты (с использованием транзакций) и 2,5 (без использования транзакций), и тормозит как мне кажется DELETE. кстати на таблицу с которой работаем есть foreign key с другой таблицы. Вот вообщем-то код: Result := -1; if ConnectionStatus = csConnected then with cmp_Query_, cmp_DataBase do begin try StartTransaction; try SQL.Text := Format('DELETE FROM Types WHERE (%s = %s) AND (types_code = -1);UPDATE Types SET flags = 1 WHERE (%s = %s) AND (flags NOT IN (1, -1))', [FSelFieldName, Val, FselFieldName, Val]; ExecSQL; Commit; Result := RowsAffected; except Rollback; raise; end; except on E: Exception do LogError(E.Message); end; end else LogError(const_msg_ErrorConnection); ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 26.09.2008, 11:15 |
|
||
|
|

start [/forum/topic.php?fid=56&fpage=23&tid=2015885]: |
0ms |
get settings: |
7ms |
get forum list: |
19ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
40ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
33ms |
get tp. blocked users: |
2ms |
| others: | 209ms |
| total: | 331ms |

| 0 / 0 |
