MySQL: Что быстрее один запрос update с inner join или select c inner join + update по списку

программирование php MySQL базы данных база данных

Что быстрее, один запрос:

update table1 a inner join table2 b on b.a_id=a.id set a.val='foo' where b='bar'

или 2 запроса:

select a.id from table1 a inner join table2 b on b.a_id=a.id where b='bar'
///php: собирем строку c id///
update a.id set a.val='foo' where id in (1,2,....)

Подозреваю, что один запрос быстрее, но не будет ли заблокирована на это время таблица, и другие запросы, проходящие параллельно будут вынуждены вставать в очередь на это время, что в результате отрицательно скажется на производительности в целом?

Примечание:
explain не работает с update/ по крайней мере у меня. вроде MyISAM
Ответы:
юзай explain, смотри время выполнения и не задавай вопросы
EXPLAIN UPDATE exists in MySQL 5.6


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.