Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

mongoid .limit does not work in mongoid 3.1.x

i tried something like this in rails with mongoid 3.1.0 and lastest 3.1.3. .limit does not work. below it should return 1 row but it returns all (4)

code:

@go = Gallery.limit(1)
logger.info "count: #{@go.count}"

output:

 count: 4
 MOPED: 54.234.11.193:10055 QUERY database=mongohqtestdatabase collection=galleries selector=  {"$query"=>{}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=-1 skip=0 batch_size=nil fields=nil (276.2010

ms)

which version of mongoid is good with limit() ?

like image 222
Axil Avatar asked Apr 18 '13 04:04

Axil


1 Answers

For Mongoid 5 the parameter of CollectionView#count changed :

    # Get a count of matching documents in the collection.
    #
    # @example Get the number of documents in the collection.
    #   collection_view.count
    #
    # @param [ Hash ] options Options for the count command.
    #
    # @option options :skip [ Integer ] The number of documents to skip.
    # @option options :hint [ Hash ] Override default index selection and force
    #   MongoDB to use a specific index for the query.
    # @option options :limit [ Integer ] Max number of docs to return.
    # @option options :max_time_ms [ Integer ] The maximum amount of time to allow the
    #   command to run.
    #
    # @return [ Integer ] The document count.
    #
    # @since 2.0.0

So you can do something like

collection.count(limit: 1) # => 1
like image 50
Geoffroy Avatar answered Oct 04 '22 13:10

Geoffroy