首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何创建一个`second_to_last`方法?

如何创建一个`second_to_last`方法?
EN

Stack Overflow用户
提问于 2013-01-13 06:28:07
回答 2查看 1.1K关注 0票数 0

我想创建一个类似于last的方法second_to_last,但它返回模型的倒数第二条记录,而不是最后一条记录。我认为这将是微不足道的,因为最后的SQL是:

代码语言:javascript
运行
复制
Select * from "users".* FROM "Users" ORDERED BY "ORDERED BY" "users"."id" DECS LIMIT 1

我必须找到一种方法将Limit 1更改为Limit 2,然后选择第一个元素。我的想法正确吗?有没有更好的方法?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-01-13 06:41:03

我想你是在正确的轨道上。尝试如下所示:

代码语言:javascript
运行
复制
User.order("created_at DESC").limit(2).last

这应该返回倒数第二条记录。

甚至还有用新方法扩展Rails的方法,但这可能超出了您的问题的范围。

更好的是,您可以使用User.last(2)。我没有比这更简单的了。

票数 2
EN

Stack Overflow用户

发布于 2013-01-13 06:33:40

如果这真的是一个rails问题,你无论如何都不需要用SQL来做。只需这样做:

代码语言:javascript
运行
复制
User.order("id DESC").offset(1).first

从字面上看,它执行以下sql查询:

代码语言:javascript
运行
复制
SELECT `users`.* FROM `users` ORDER BY id DESC LIMIT 1 OFFSET 1
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14298614

复制
相关文章

相似问题

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