我正在 10 月 cms 上创建前端排行榜。我目前使用的系统如下:
当我编辑将值存储在 db 上的输入之一时,javascript 获取该值并将其与隐藏输入中的所有其他值相加,该隐藏输入将总和存储在 db 字段中。
因此,当我想按总分获取记录列表时,我只需要:
use RainLab\User\Models\User;
function onInit() {
$this['activatedUsers'] = User::whereIsActivated(true)->orderBy('RankPoints', 'desc')->get();
}
按包含总和的字段对结果进行排序。
这就是目前的情况并且工作得很好。我想要实现的是按一个变量(例如 x)对记录进行排序。但是如果两个用户的 x 值相同,它会用另一个变量 (y) 对它们进行排序。最终我想用两个以上的变量来做这个,但我想从这个简单的两个变量系统开始,这样我就可以理解思考过程。
例子:
使用当前方法,用户 (a) 位于用户 (b) 之上,因为它在其他变量中具有更高的数字。但是,如果我想按级别对所有用户进行排序,然后按健身房积分排序,则玩家 (b) 实际上会排在首位。
希望大家能理解和帮助,先谢谢了。
编辑:
在查询中使用第二个变量添加第二个 orderby 似乎有效,这种方法是否正确?
使用 MySQL,可以简单地使用多个ORDER BY
条件按多个值对结果进行排序。
例如,以下将首先按级别对用户进行排序,然后按排名点排序。
$users = User::whereIsActivated(true)
->orderBy('Level', 'desc') // x
->orderBy('RankPoints', 'desc') // y
->get();
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句