Mysql
 sql >> Base de données >  >> RDS >> Mysql

mysql:Comment INNER JOIN une table mais limiter la jointure à 1 résultat avec le vote ou le nombre le plus élevé?

SELECT a.*, b.*
  FROM Items a
       LEFT JOIN Votes b on a.item_id = b.item_id
                         and b.total_yes = (select max(total_yes) 
                                              from Votes v 
                         where v.item_id = a.item_id)
ORDER BY a.post_date DESC, b.total_yes DESC

N.B. :si vous avez pour un item 2 réponses avec le même total_yes =max, vous aurez 2 lignes pour cet item.