我有一个用户模型和一个故事模型。用户有很多故事。
我想创建一个范围,返回今天创建故事最多的用户的25个用户记录,以及他们创建的故事数量。
我知道有些人对active_records查询很在行。我也知道我不是那种人:-(。我们将非常感谢并欣然接受帮助!
#随解决方案更新
我一直在使用@MrYoshiji先生的建议,下面是我想出来的(注意,我在我的active_admin仪表板中使用了这个查询):
panel "Today's Top Posters" do
time_range = Date.today.beginning_of_day..Date.today.end_of_day
table_for User.joins(:stories)
.select('users.username, count(stories.*) as story_count')
.group('users.id')
.where(:stories => {:created_at => time_range})
.order('story_count DESC')
.limit(25) do
column :username
column "story_count"
end
end低头看,它成功了!
请注意,当我尝试MrYoshiji先生的建议的简化版本时:
User.includes(:stories)
.select('users.username, count(stories.*) as story_count')
.order('story_count DESC') #with or without the group statement
.limit(25)我得到了以下错误:
> User.includes(:stories).select('users.username, count(stories.*) as story_count').order('story_count DESC').limit(25)
User Load (1.6ms) SELECT DISTINCT "users".id, story_count AS alias_0 FROM "users" LEFT OUTER JOIN "stories" ON "stories"."user_id" = "users"."id" ORDER BY story_count DESC LIMIT 25
ActiveRecord::StatementInvalid: PG::Error: ERROR: column "story_count" does not exist
LINE 1: SELECT DISTINCT "users".id, story_count AS alias_0 FROM "us...似乎includes不喜欢任何别名。
发布于 2013-02-24 05:50:20
按照MrYshiji的建议,使用.includes由于别名问题而不起作用(有关这方面的更多信息,请参阅原始问题)。相反,我使用了如下所示的.joins来获得我想要的查询结果(注意,这个查询在我的active_admin仪表板中):
panel "Today's Top Posters" do
time_range = Date.today.beginning_of_day..Date.today.end_of_day
table_for User.joins(:stories)
.select('users.username, count(stories.*) as story_count')
.group('users.id')
.where(:stories => {:created_at => time_range})
.order('story_count DESC')
.limit(25) do
column :username
column "story_count"
end
end发布于 2013-02-13 08:19:19
我现在不能测试它,在Windows下运行...你能试试吗?
User.includes(:stories)
.select('users.*, count(stories.*) as story_count')
.group('users.id')
.order('story_count DESC')
.where('stories.created_at BETWEEN ? AND ?', Date.today.beginning_of_day, Day.today.end_of_day)
.limit(25)https://stackoverflow.com/questions/14844275
复制相似问题