Как получить МАКСИМАЛЬНУЮ дату в заявлении INNER JOIN - PullRequest
0 голосов
/ 25 ноября 2018

Я хочу получить статус заказа, где статус регистрируется в отдельной таблице 'order_status_change'.Используя следующий скрипт, я смог получить все записи, но не последний статус.(Требуется статус для order_item_ID для max (status change_date).

 SET @UserID = 160;
    SET @OrderDateTime = '2018-11-13 09:23:45';

    SELECT 
order_items.ORDER_ITEM_ID,
order_price.ORDER_ITEM_TOTAL_PRICE,
order_status_change.ORDER_STATUS

FROM order_items 

INNER JOIN order_price ON order_price.ORDERP_ITEM_ID = order_items.ORDER_ITEM_ID

INNER JOIN order_status_change ON order_status_change.ORDER_ITEM_ID = order_items.ORDER_ITEM_ID

WHERE ((SELECT A.A_User_ID from A WHERE A.A_USER_ID = @UserID) AND (DATE(order_items.ORDER_REQUIRED_DATE_TIME) = DATE(@OrderDateTime)))

Если я использую Max (order_status_change.STATUS_CHANGE_DATE), тогда я получаю только одну запись. Я изменил запрос, посмотрев другой пример здесь, но неработает.

SELECT 
order_items.ORDER_ITEM_ID,
order_price.ORDER_ITEM_TOTAL_PRICE,
order_status_change.ORDER_STATUS

FROM order_items 

INNER JOIN order_price ON order_price.ORDERP_ITEM_ID = order_items.ORDER_ITEM_ID

INNER JOIN 
(SELECT MAX(order_status_change.ORDER_STATUS_CHANGE_DATETIME) AS STATUS_CHANGED_DATE FROM order_status_change WHERE order_status_change.ORDER_ITEM_ID = order_items.ORDER_ITEM_ID) 
AS order_status_change ON order_status_change.ORDER_ITEM_ID = order_items.ORDER_ITEM_ID

WHERE ((SELECT A.A_User_ID from A WHERE A.A_User_ID = @UserID) AND (DATE(order_items.ORDER_REQUIRED_DATE_TIME) = DATE(@OrderDateTime)))

Как я могу получить 'LATEST' order_status_change.STATUS для каждого order_items.ORDER_ITEM_ID?

1 Ответ

0 голосов
/ 25 ноября 2018

Вы можете попробовать это.

SELECT 
    order_items.ORDER_ITEM_ID,
    order_price.ORDER_ITEM_TOTAL_PRICE,
    order_status_change.ORDER_STATUS
FROM order_items 
INNER JOIN order_price ON order_price.ORDERP_ITEM_ID = order_items.ORDER_ITEM_ID
INNER JOIN 
(
    SELECT MAX(order_status_change.ORDER_STATUS_CHANGE_DATETIME) AS STATUS_CHANGED_DATE,ORDER_ITEM_ID
    FROM order_status_change 
    GROUP BY ORDER_ITEM_ID
) AS order_status_change ON order_status_change.ORDER_ITEM_ID = order_items.ORDER_ITEM_ID
WHERE (
    (DATE(order_items.ORDER_REQUIRED_DATE_TIME) = DATE(@OrderDateTime))
)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...