0

好的,所以我有一个评级表。为每个留下评分的用户创建一个新行。我试图做的是创建一个查询,该查询将返回现在和 7 天前存在的每个特定行的评级值。

广义的观点是,我想计算总平均评分与 7 天前的总平均评分的差异。

我有这个,我认为这是正确的道路,但我得到了

Unknown column 'start_ratings.menu_item_id' in 'on clause'

SELECT *
FROM ratings end_ratings
JOIN (
SELECT menu_item_id as end_menu_item_id, AVG(value) AS end_rating
    FROM ratings
    WHERE  
        created_at > current_date - 7
        AND menu_item_id IS NOT NULL
        AND location_id IS NOT NULL
    GROUP BY menu_item_id
) start_ratings ON (end_ratings.menu_item_id = start_ratings.menu_item_id)
WHERE menu_item_id IS NOT NULL
AND location_id IS NOT NULL;
4

1 回答 1

3

您已为该列添加别名as end_menu_item_id。只需使用它,因为()ON子句、SELECT列表等中的派生表之外,只有别名是已知的......

因为这:

SELECT menu_item_id as end_menu_item_id, 
/*-----------------^^^^^^^^^^^^^^^^^^^^^^ */

用这个:

...) start_ratings ON (end_ratings.menu_item_id = start_ratings.end_menu_item_id)
/*----------------------------------------------------------^^^^^^^^^^^^^^^^^^^^^^^ */
于 2013-01-22T20:05:38.573 回答