Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Производительность UPDATE при JOIN 
V
    Опции темы
maxipub
Дата 23.3.2018, 18:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 517
Регистрация: 22.10.2009

Репутация: 1
Всего: 1



Если взять запрос вида:

Код
UPDATE t1
INNER JOIN t2 on t2.sub_id=t1.id 
INNER JOIN t3 on t3.sub_id=t1.id 
SET t1.data=111 
WHERE t1.name=222


В таблице t1 десять полей с name=222. Если заменить UPDATE на аналогичный SELECT, будет нечто вроде:

Код
SELECT * FROM t1
INNER JOIN t2 on t2.sub_id=t1.id 
INNER JOIN t3 on t3.sub_id=t1.id 

WHERE t1.name=222


Получим выборку на несколько тысяч строк.

Вопрос: такой UPDATE будет аналогичен нескольким тысячам UPDATE-ов, т.е. как все SELECT-ится, так все будет и UPDATE-тится и надо думать над каким-нибудь GROUP BY, или UPDATE в данном случае будет выполняться по оптимальному сценарию, и одни и те же данные не будут по кругу гоняться?
PM MAIL   Вверх
Akina
Дата 23.3.2018, 22:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



Запись обновляется только один раз. 


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
maxipub
Дата 27.3.2018, 11:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 517
Регистрация: 22.10.2009

Репутация: 1
Всего: 1



Akina, да, похоже так оно и есть. Провел тест, количество затрагиваемых строк говорит о том же.
PM MAIL   Вверх
Akina
Дата 27.3.2018, 12:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



Цитата(maxipub @  27.3.2018,  12:01 Найти цитируемый пост)
похоже так оно и есть

Это документировано.

Цитата(https://dev.mysql.com/doc/refman/5.7/en/update.html)

Each matching row is updated once, even if it matches the conditions multiple times.



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.1185 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.