Перемещение полей в другую таблицу и использование этого идентификатора для обновления строк в третьей таблице

У меня есть три таблицы под названием «itemorders», «mycart» и «products». В настоящее время я перемещаю товары в mycart в таблицу itemorders, как это в моем мультизапросе.

$query = "INSERT into itemorders 
  (itemID,itemName,itemSize,itemColour,itemPrice,quantity,orderID) 
   SELECT itemID,itemName,itemSize,itemColour,itemPrice,quantity, 
 LAST_INSERT_ID() FROM mycart WHERE email='".$email."'  ";

Как мне использовать itemID, itemColour и количество из моего запроса и использовать их для обновления поля количества в таблице продуктов?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
27
1

Ответы 1

Вы можете использовать UPDATE INNER JOIN (https://dev.mysql.com/doc/refman/5.5/en/update.html), если в вашей таблице itemorders также есть столбец AUTO_INCREMENT.

Что-то типа:

UPDATE products p
INNER JOIN itemorders i ON p.itemID = i.itemID AND p.itemColour = i.itemColour
SET p.quantity = p.quantity - i.quantity
WHERE i.ID = LAST_INSERT_ID()

Я не проверял это, и обеспечение того, чтобы вы справились с бизнес-инвариантами, избегая отрицательного подсчета запасов, остается читателю в качестве упражнения.

P.S. Also be careful about SQL injection attacks (the way you are interpolating the email may make life harder for poor Bobby Tables. https://xkcd.com/327/), I'd recommend looking into PDO http://php.net/manual/en/pdostatement.bindvalue.php.

Привет, это работает с несколькими строками? Допустим, я вставил 2 уникальные строки в первый запрос, обновит ли он 2 уникальных продукта?

ken 22.01.2019 10:31

Другие вопросы по теме