繁体   English   中英

SQL在组MAX()值的其他列中查找行值-MySQL

[英]SQL find row value in other column of groups MAX() value - MySQL

我有三个表,分别包含电影,评分和评论者数据。 我的数据联接如下所示:

mysql root@localhost:foo> SELECT m.title, ra.stars, re.name
                       -> FROM Movie m
                       -> JOIN Rating ra ON m.mid = ra.mid
                       -> JOIN `Reviewer` re ON ra.rid = re.rid
                       -> ORDER BY m.title, ra.stars DESC;
+-------------------------+-------+------------------+
| title                   | stars | name             |
+-------------------------+-------+------------------+
| Avatar                  | 5     | James Cameron    |
| Avatar                  | 3     | Elizabeth Thomas |
| E.T.                    | 3     | Ashley White     |
| E.T.                    | 2     | Chris Jackson    |
| Gone with the Wind      | 4     | Sarah Martinez   |
| Gone with the Wind      | 3     | Mike Anderson    |
| Gone with the Wind      | 2     | Sarah Martinez   |
| Raiders of the Lost Ark | 4     | Brittany Harris  |
| Raiders of the Lost Ark | 4     | Chris Jackson    |
| Raiders of the Lost Ark | 2     | Brittany Harris  |
| Snow White              | 5     | Elizabeth Thomas |
| Snow White              | 4     | Daniel Lewis     |
| The Sound of Music      | 3     | Chris Jackson    |
| The Sound of Music      | 2     | Brittany Harris  |
+-------------------------+-------+------------------+

我想要实现的是按标题对上表进行分组,并获得给予每部电影最高评价的评论者的姓名。 结果应如下所示。

+-------------------------+-------+------------------+
| title                   | stars | name             |
+-------------------------+-------+------------------+
| Avatar                  | 5     | James Cameron    |
| E.T.                    | 3     | Ashley White     |
| Gone with the Wind      | 4     | Sarah Martinez   |
| Raiders of the Lost Ark | 4     | Brittany Harris  |
| Raiders of the Lost Ark | 4     | Chris Jackson    |
| Snow White              | 5     | Elizabeth Thomas |
| The Sound of Music      | 3     | Chris Jackson    |
+-------------------------+-------+------------------+

我在某种程度上陷入了困境。 谁能指出我正确的方向?

编辑:我最初虽然在stars列( MAX(stars) )上包含另一个聚合函数很简单,但是我无法使其正常工作。 任何想法可能如何工作?

解决方案1: -从结果集中:

SELECT A.* 
FROM Your_Table A
JOIN(
    SELECT title,MAX(stars) stars
    FROM Your_Table
    GROUP BY title
    )B ON A.title = B.title AND A.stars = B.stars

第二种解决方案: -从您的餐桌上

SELECT m.title, ra.stars, re.name
FROM Movie m
JOIN(
    SELECT R.* 
    FROM Rating R
    JOIN(
        SELECT mid
            ,MAX(stars) Stars
        FROM Rating
        GROUP BY mid
        )D ON R.mid = D.mid AND R.Stars = D.Stars
    )Ra ON m.mid = ra.mid
JOIN Reviewer re ON ra.rid = re.rid
SELECT m.title, ra.stars, re.name
FROM Movie m
JOIN (SELECT mid,MAX(stars) AS stars FROM Rating GROUP BY mid) ra 
ON m.mid = ra.mid
JOIN Rating ra1
ON ra1.mid = ra.mid AND ra1.star=ra.star
JOIN Reviewer re 
ON ra1.rid = re.rid
ORDER BY m.title, ra.stars DESC;
 SELECT m.title, ra.stars, re.name
       FROM Movie m
      JOIN Rating ra ON m.mid = ra.mid
      JOIN Reviewer re ON ra.rid = re.rid
      JOIN 
 (SELECT m.title, max(ra.stars) as stars
       FROM Movie m
      JOIN Rating ra ON m.mid = ra.mid
      GROUP BY m.title) c
ON c.title=m.title AND ra.stars=c.stars
      ORDER BY m.title, ra.stars DESC

以下代码将对您有所帮助,

SELECT m.title, ra.stars, re.name
FROM Movie m
JOIN Rating ra ON m.mid = ra.mid
JOIN Reviewer re ON ra.rid = re.rid
WHERE ra.stars = ( SELECT MAX(ra1.stars) FROM Movie m1 JOIN Rating ra1 on m1.mid = ra1.mid WHERE m1.title = m.title) 
ORDER BY m.title, ra.stars DESC;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM