Как превратить INSERT INTO ON DUPLICATE KEY UPDATE в множественный запрос, ЕСЛИ ВЫ обновляете ключ

Как превратить эти два запроса в один:

INSERT INTO planet_market (resource_id, price,amount) VALUES 
(6, 999, 100)
ON DUPLICATE KEY UPDATE
amount = amount + 100

INSERT INTO planet_market (resource_id, price,amount) VALUES 
(6, 777, 60)
ON DUPLICATE KEY UPDATE
amount = amount + 60

в множественный запрос

INSERT INTO planet_market (resource_id, amount, type, price,owner_type,planet_id, factory_id)  
VALUES (6, 999, 100),
(6, 777, 60)
ON DUPLICATE KEY UPDATE
amount = amount + VALUES(amount)

РЕДАКТИРОВАТЬ !!!: у меня он работает с суммой = сумма + ЗНАЧЕНИЯ (сумма)

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

Не могли бы вы уточнить свой вопрос и предоставить небольшой образец схемы, а также ожидаемые результаты?

Martin 07.09.2018 12:29

@Martin Я упростил и расширил вопрос, теперь он должен быть более понятным. Не думайте, что вам нужна схема, чтобы понять это сейчас.

Asgarnian 07.09.2018 12:52

ммм, я думаю, я просто получил его, чтобы работать с количеством = количество + ЗНАЧЕНИЯ (количество) lol

Asgarnian 07.09.2018 12:54
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
3
29
1

Ответы 1

Я думаю, вам следует использовать функцию SUM().

amount = SUM(amount + VALUES(amount))

Знаете ли вы, что лучше, чем просто: количество = количество + ЗНАЧЕНИЯ (количество)?

Asgarnian 07.09.2018 13:09

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