2

我可以显示商店内的商品及其评论。如何获得评论最多的顶级商品?我的评论在另一个数据库表中,而不是 shop 和 item。

控制器

@shop = Shop.find(params[:id]) 
@item = Item.where(:shop_name => @shop.name)

看法

<% @item.each do |u| %>
  <%= u.reviews.average('rating') %>
  <%= u.reviews.count %>
<% end %>

有没有一种简单的方法可以让我根据评论最多的最高评分来订购?或者也许最好将最高评分和大多数评论分开并让用户点击链接进行过滤?

谢谢

编辑:

所以我有一个shop, item,review表。

在我的物品模型中

has_many :reviews, as: :reviewable
has_many :shops

在我的评论模型商店模型

belongs_to :user

在我的评论表中,它设置为当用户评论一个项目时,它会向数据库中添加一条记录,我使用average与该项目关联的所有记录中的一个并将其显示在商店中。

4

1 回答 1

5

如果我理解正确你的 ER 模型,你可以试试这个:

@items = Item.where(:shop_name => @shop.name).joins(:reviews)
  .select("items.id, avg(reviews.rating) as average_rating, count(reviews.id) as number_of_reviews")
  .group("items.id")
  .order("average_rating DESC, number_of_reviews DESC")

可能有一些错别字,但你明白了。也可能你会想要创建某种加权分数,否则在这种情况下,一个 5 星评论的项目将高于 50 个 4 星评论的项目。

此外,我在块中定义的所有自定义列select都将是字符串类型,因此如果您将对它们进行任何算术运算,则需要手动对它们进行类型转换。

于 2013-10-12T21:36:29.777 回答