首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >请按语法排序Mongoid作用域

请按语法排序Mongoid作用域
EN

Stack Overflow用户
提问于 2011-06-14 11:26:26
回答 1查看 12.8K关注 0票数 18

我在用最新的mongoid..。

如何执行此active record named_scope的mongoid等效项:

代码语言:javascript
复制
class Comment
  include Mongoid::Document
  include Mongoid::Timestamps

  embedded_in :post

  field :body, :type => String

  named_scope :recent, :limit => 100, :order => 'created_at DESC'
...
end
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-06-14 12:32:43

它必须这样定义

代码语言:javascript
复制
scope :recent, order_by(:created_at => :desc).limit(100)

您可以查看范围here的mongoid文档

从页面

命名作用域是使用作用域宏在类级别定义的,并且可以链接起来以在一个很好的DSL中创建结果集。

代码语言:javascript
复制
class Person
  include Mongoid::Document
  field :occupation, type: String
  field :age, type: Integer

  scope :rock_n_rolla, where(occupation: "Rockstar")
  scope :washed_up, where(:age.gt => 30)
  scope :over, ->(limit) { where(:age.gt => limit) }
end

# Find all the rockstars.
Person.rock_n_rolla

# Find all rockstars that should probably quit.
Person.washed_up.rock_n_rolla

# Find a criteria with Keith Richards in it.
Person.rock_n_rolla.over(60)
票数 36
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6338752

复制
相关文章

相似问题

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