Задать вопрос
@AndreyBerezov

Как сделать сложный UPDATE запрос к MySQL для частичного слияния данных двух таблиц?

Доброго времени суток!
Подскажите, как правильно сделать запрос для обновления данных, если есть 2 таблицы, в каждой из которых есть поля user_id и unicnumber. Нужно взять из одной таблицы пару table1.user_id->table1.unicnumber (1 к 1) и скопировать значение unicnumber всем записям другой таблицы, где table1.user_id совпадает table2.user_id. Получится table2.user_id->table2.unicnumber (Многие к одному).
Запрос на получение из первой таблицы такой: SELECT user_id, unicnumber FROM table1 WHERE accept = 1;
Пример запроса на обновление в другой таблицы такое: UPDATE table2 SET unicnumber = 1234 WHERE table2.user_id = 1;

Можно в цикле PHP выполнить 100000 запросов, формируя их, исходя из полученных данных первого запроса. Но, может, есть решение изящнее с помощью MySQL?
  • Вопрос задан
  • 385 просмотров
Подписаться 2 Оценить Комментировать
Помогут разобраться в теме Все курсы
  • Skillbox
    Веб-разработчик на PHP
    9 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
Melkij
@Melkij
DBA для вашего PostgreSQL?
update table2 
join table1 using(user_id)
 set table2.unicnumber = table1.unicnumber 
where table1.accept = 1

?
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽