В чем моя ошибка при выборе «coalesce mysql»?

У меня есть столбец discount_amount, если нет SUM(discount_amount) (NULL) ТО ноль (0).

Я написал запрос с этим

SELECT COALESCE(SUM(discount_amount) 
FROM order_discount
WHERE order_discount.discount_type_id = 6
  AND order_discount.order_match_id = om1.id, 0);

но я получаю сообщение об ошибке

Код ошибки: 1064. У вас ошибка в синтаксисе SQL; проверьте руководство, соответствующее версии вашего сервера MySQL, для правильного синтаксиса для использования рядом с «FROM order_discount WHERE order_discount.discou» в строке 2.

Освоение архитектуры микросервисов с 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
0
64
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы, кажется, хотите:

SELECT COALESCE(SUM(discount_amount), 0)
FROM order_discount
WHERE order_discount.discount_type_id = 6 AND order_discount.order_match_id = om1.id;

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

В качестве альтернативы вы можете COALESCE() получить результат подзапроса следующим образом:

COALESCE(
    (
        SELECT SUM(discount_amount) 
        FROM order_discount
        WHERE order_discount.discount_type_id = 6 AND order_discount.order_match_id = om1.id
    ),
    0
)

Опять же, это имеет смысл только в том случае, если оно включено в более крупный запрос.

оба они дадут тот же результат, который я хочу, или это другой результат?

18Man 14.12.2020 09:48

@FachryDzaky: оба дают одинаковый результат. Но вы бы включили их по-разному во весь запрос (который вы не показали).

GMB 14.12.2020 09:55

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