按关联模型的平均值对模型进行排序的activerecord查询。
创始人
2024-10-14 10:31:07
0

要按关联模型的平均值对模型进行排序,可以使用ActiveRecord查询。下面是一个示例代码,假设有两个模型:UserPost,并且UserPost之间有一个一对多的关联关系。

首先,需要在User模型中定义一个关联方法,用来获取用户的所有帖子:

class User < ApplicationRecord
  has_many :posts
end

然后,可以使用ActiveRecord查询按关联模型的平均值对用户进行排序。以下是示例代码:

User.joins(:posts)
    .select("users.*, AVG(posts.rating) AS avg_rating")
    .group("users.id")
    .order("avg_rating DESC")

上述代码中,使用joins方法将User模型与Post模型关联起来。然后,使用select方法选择需要的字段,并使用AVG函数计算每个用户的帖子评分的平均值,并将其命名为avg_rating。接下来,使用group方法按users.id分组,以确保每个用户只出现一次。最后,使用order方法按avg_rating字段的降序进行排序。

这样,就可以按关联模型的平均值对用户进行排序了。你可以根据自己的需求进行适当的修改和调整。

相关内容

热门资讯

约局吧德州透视!aapoker... 约局吧德州透视!aapoker辅助器是真的吗(透视)app-都是分享真的是有挂1、玩家可以在aapo...
wejoker黑侠辅助器!we... wejoker黑侠辅助器!wepoker祈福有用吗(透视)软件-一直专业真的有挂1.wepoker祈...
wepoker科技辅助器!HH... wepoker科技辅助器!HH平台挂(透视)app-一直专业存在有挂1、进入游戏-大厅左侧-新手福利...
hhpkoer辅助器!werp... hhpkoer辅助器!werplan怎么透视(透视)攻略-竟然教你是真的挂1、每一步都需要思考,不同...
wepoker透视脚本视频!a... wepoker透视脚本视频!aapoker免费透视脚本(透视)app-切实透视真的是有挂1、aapo...
德普之星透视辅助软件激活码!a... 德普之星透视辅助软件激活码!aapoker怎么提高中牌率(透视)神器-竟然辅助是真的挂1、让任何用户...
wepoker透视底牌脚本!红... wepoker透视底牌脚本!红龙poker透视指令(透视)器-本来分享存在有挂;1、许多玩家不知道w...
wepoker免费脚本弱密码!... wepoker免费脚本弱密码!wejoker透视方法(透视)脚本-竟然曝光是有挂1、超多福利:超高返...
德普之星私人局辅助器!wepo... 德普之星私人局辅助器!wepoker好友房开挂(透视)app-总是科普有挂1、在德普之星私人局辅助器...
wepoker私人辅助器!ha... wepoker私人辅助器!hardrock透视工具(透视)插件-原来揭幕是有挂1、每一步都需要思考,...