Skip to content

Latest commit

 

History

History
35 lines (29 loc) · 1.8 KB

README.rdoc

File metadata and controls

35 lines (29 loc) · 1.8 KB

mongoid_auto_inc

Add SQL like auto-incrementing fields to your Mongoid documents.

This gem is inspired by ihswebdesign.com/blog/autoincrement-in-mongodb-with-ruby/ and the mongomapper_id2 gem.

Install

In your Gemfile:

gem 'mongoid_auto_inc'

Followed by running bundle install, or do:

gem install mongoid_auto_inc

Usage

Just add auto_increment :field to your Mongoid model where :field is the name of the auto-incremented field you want to create. Example:

class Book
  include Mongoid::Document

  field :title
  field :author

  auto_increment :sequence
end

auto_increment :sequence will create a field of type Integer named sequence for Book. Whenever an instance of the model is created (intially saved to mongoDB), the auto_increment field will automatically be set to the next number in the sequence.

You can add more than one auto-incremented field per model.

Options

auto_increment :sequence, :collection => :some_collection

mongoid_auto_inc keeps track of the current number in the sequence by creating a separate document mongoDB to query and update. By default auto_increment will save this document to a mongoDB collection called sequences. If you wish to save to a different collection use the :collection option to specify its name.

auto_increment :sequence, :seed => 3333

Use the :seed option to set the initial value of the auto-incremented field. The first number assigned from the sequence will be the next number after the seed value.

Contributors

Thanks to these folk for their help: