У меня есть три таблицы под названием «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 и количество из моего запроса и использовать их для обновления поля количества в таблице продуктов?






Вы можете использовать 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 уникальных продукта?