首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >find_with_reputation的多阶值

find_with_reputation的多阶值
EN

Stack Overflow用户
提问于 2013-11-15 12:36:15
回答 1查看 77关注 0票数 0

下面的函数按投票降序(使用活动记录声誉系统链接到宝石)对业务(关系)进行排序。

代码语言:javascript
复制
@businesses = Business.find_with_reputation(:votes, :all, order: "votes desc")

我如何添加二级顺序值,使其按选票排序,但如果票数相等,则按created_at排序(顶部最老的)。

是否简单地:

代码语言:javascript
复制
@businesses = Business.find_with_reputation(:votes, :all, order: "votes desc, created_at desc")
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-11-15 14:59:59

我怀疑您提出的答案会导致SQL错误,因为'created_at‘可能同时出现在信誉表和业务表中。为了避免这种情况,我建议在created_at上做一些具体的说明。

代码语言:javascript
复制
Business.find_with_reputation(:votes, :all, order: "votes desc, businesses.created_at desc")

但是,我建议您使用id列。DBs在INT中会更快,排序顺序应该是相同的。

代码语言:javascript
复制
Business.find_with_reputation(:votes, :all, order: "votes desc, businesses.id desc")
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20001246

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档