Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
пакетное добавление данных в индексированную таблицу
|
|||
|---|---|---|---|
|
#18+
У меня есть таблица с жирными индексами. И в нее постоянно идет запись. Если вот эти данные писать не по одной, а скажем по 10-20-50 в одной транзакции - это быстрее будет? Индекс обновляеться для кажой записи или при каждой транзакции? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 10.05.2017, 21:00 |
|
||
|
пакетное добавление данных в индексированную таблицу
|
|||
|---|---|---|---|
|
#18+
alexnewsИндекс обновляеться для кажой записи или при каждой транзакции?Для каждой записи. Впрочем, вопрос особого смысла не имеет, т.к. все равно разные записи будут попадать в разные блоки индексов. Но, тем не менее, группировать несколько вставок в транзакции имеет некоторый смысл. И покажите код вставки, возможно, еще что-то можно будет предложить. Например, если поток реально большой, то имеет смысл буферизировать данные в файле, а потом вставлять их все разом командой LOAD DATA. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 10.05.2017, 21:25 |
|
||
|
пакетное добавление данных в индексированную таблицу
|
|||
|---|---|---|---|
|
#18+
. Если вот эти данные писать не по одной, а скажем по 10-20-50 в одной транзакции - это быстрее будет? быстрее будет, но не очень сильно. лучше больше, по несколько тысяч записей. Индекс обновляеться для кажой записи или при каждой транзакции? это дело энджина, в принципе, для каждой транзакции, но это тебе не поможет. короче, пакетируй по несколько тысяч записей в один insert, это автоматом будет одна транзакции, и один пакет (посылка) на сервер. Да, если у тебя Isam, транзакций нет. но все равно надо делать так же. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.05.2017, 09:54 |
|
||
|
пакетное добавление данных в индексированную таблицу
|
|||
|---|---|---|---|
|
#18+
Спасибо за ответы, движек Innodb, решили делать реально транзакцию: генерю строку с 5 тыс insert'ов. Если я ее просто execute - то 5 секунд, если между START TRANSACTION и COMMIT - 0.36 секунды. Еще раз спасибо за ответы. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.05.2017, 17:49 |
|
||
|
|

start [/forum/topic.php?fid=47&msg=39451020&tid=1830687]: |
0ms |
get settings: |
9ms |
get forum list: |
12ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
58ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
43ms |
get tp. blocked users: |
1ms |
| others: | 13ms |
| total: | 156ms |

| 0 / 0 |
