Arhn - архитектура программирования

SQL-запрос не дает правильных результатов

У меня есть 4 таблицы:

  1. Клиенты со столбцами - имя пользователя, пароль, имя и т. д.
  2. Книги со столбцами - идентификатор, название, автор и т. д.
  3. order_details со столбцами - id_order, id(id книги) и т.д.
  4. user_order со столбцами — id_order, имя пользователя, пароль, электронная почта и т. д.

И я хочу распечатать таблицу со столбцами order_date, названием книг, ценой книг и количеством книг, которая отображает историю заказов для конкретного пользователя за последние 3 месяца.

Я использую следующий запрос SQL:

SELECT user_order.Order_Date, books.title, books.Price, Order_Details.Quantity
from Customers INNER JOIN user_order ON Customers.username = user_order.username
INNER JOIN Order_Details ON Order_Details.ID_Order = user_order.ID_Order
INNER JOIN books ON books.id = order_Details.ID
AND Customers.username = '".$username."' 
where user_order.ORDER_DATE < ADD_MONTHS(user_order.ORDER_DATE, 3)

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

Может ли кто-нибудь помочь мне в исправлении запроса?

27.09.2015

Ответы:


1

С вашей командой ADD_MONTHS вы получаете дату через 3 месяца. Поэтому, говоря ORDER_DATE < 3MonthsInFuture, вы запрашиваете все существующие даты заказа.

27.09.2015
  • Да, это была одна из проблем, в таблицах также были некоторые избыточные данные, которые вызывали эту проблему. Большое спасибо за помощь 27.09.2015
  • Добро пожаловать. Если вы удовлетворены моим ответом, отметьте его как принятый, чтобы вопрос можно было закрыть. 27.09.2015
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..