Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

mysql:Como INNER JOIN em uma tabela, mas limita a junção a 1 resultado com o maior voto ou contagem?

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.:se você tiver para um item 2 respostas com o mesmo total_yes =max, você terá 2 linhas para esse item.