|
Как быстрее обновить диапазон строк (месяц) в годовой SQLite базе?
|
|||
---|---|---|---|
#18+
База за 3 года, 1 табл из 4 млн строк х 50 полей, перв. ключа (PK) нет, индексы все есть. Данные импортируются помесячно (по ~100 тыс. строк), больше не позволяет оболочка 1С, в обычном порядке месяцев 1-2-3...11-12 Но так как это бухгалтерия ~:-( - то часто "задним" числом меняются проводки, поэтому после ноября (11) может обновиться март (3). Держать месяцы в разных таблицах плохо - скорость запросов падает в 3 раза. Посоветуйте как быстрее импортировать "новые" месяцы в БД и чтобы запросы (с... по...) работали быстро. Время импорта и реиндекса примерно одинаково (2 мин на 100 тыс. строк). REPLACE неприменим из-за отсутствия PK. Есть идеи: 1) Обнаружив скриптом новый "март" - сносить все строки с этого месяца Код: plaintext
2) Удалять один старый "март" Код: plaintext
Что посоветуете новичку!? ... |
|||
:
Нравится:
Не нравится:
|
|||
17.05.2011, 11:45 |
|
Как быстрее обновить диапазон строк (месяц) в годовой SQLite базе?
|
|||
---|---|---|---|
#18+
economistalexперв. ключа (PK) нет [skipped] REPLACE неприменим из-за отсутствия PK. Ну дак попробуй создать его. Поскольку напрямую это невозможно, придётся создать другую таблицу, перекинуть в неё данные из старой, снести старую и переименовать на её место новую. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.05.2011, 08:52 |
|
|
start [/forum/search_topic.php?author=DofD&author_mode=last_posts&do_search=1]: |
0ms |
get settings: |
11ms |
get forum list: |
12ms |
get settings: |
11ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
70ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
36ms |
get tp. blocked users: |
1ms |
others: | 1253ms |
total: | 1428ms |
0 / 0 |