Получить данные из диапазона дат, но по области

Я пытаюсь получить данные из диапазона дат и где площадь офиса равна office->id area. Вот мой запрос

SELECT * FROM office as d
      LEFT JOIN office_area as e ON e.ID_Area = d.ID_Area
      WHERE d.ID_Area = 1 OR d.ID_Area = 6
      AND d.date BETWEEN '2018-09-01' AND '2018-09-30'
    ORDER BY d.date DESC

Проблема в том, что я получаю данные с датой 2018-01-01, потому что первое, где. Как я могу получить только данные из области 1 и 6 из этого диапазона дат

MySQL или Sql-сервер?

Madhur Bhaiya 13.09.2018 20:17

Вам нужно разделить где условия WHERE ( d.ID_Area = 1 OR d.ID_Area = 6 ) AND (d.date BETWEEN '2018-09-01' AND '2018-09-30')

PrathapG 13.09.2018 20:22
Освоение архитектуры микросервисов с 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
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
2
2
34
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

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

Просто нужны скобки:

SELECT * FROM office as d
  LEFT JOIN office_area as e ON e.ID_Area = d.ID_Area
  WHERE (d.ID_Area = 1 OR d.ID_Area = 6)
  AND d.date BETWEEN '2018-09-01' AND '2018-09-30'
ORDER BY d.date DESC

Если у вас хватит фантазии, вы даже можете использовать синтаксис IN ():

SELECT * FROM office as d
  LEFT JOIN office_area as e ON e.ID_Area = d.ID_Area
  WHERE d.ID_Area IN (1, 6)
  AND d.date BETWEEN '2018-09-01' AND '2018-09-30'
ORDER BY d.date DESC

используйте in вместо OR

SELECT * FROM office as d
      LEFT JOIN office_area as e ON e.ID_Area = d.ID_Area
      WHERE d.ID_Area (1,6)
      AND d.date BETWEEN '2018-09-01' AND '2018-09-30'
    ORDER BY d.date DESC

Или используйте круглые скобки

SELECT * FROM office as d
  LEFT JOIN office_area as e ON e.ID_Area = d.ID_Area
  WHERE (d.ID_Area = 1 OR d.ID_Area = 6)
  AND d.date BETWEEN '2018-09-01' AND '2018-09-30'
ORDER BY d.date DESC

Вам нужно добавить несколько круглых скобок, чтобы отсортировать логику:

SELECT * FROM office as d
  LEFT JOIN office_area as e ON e.ID_Area = d.ID_Area
  WHERE (d.ID_Area = 1 OR d.ID_Area = 6)
  AND (d.date BETWEEN '2018-09-01' AND '2018-09-30')
ORDER BY d.date DESC

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