Module: Mongoid::Persistable::Creatable::ClassMethods

Defined in:
build/mongoid-master/lib/mongoid/persistable/creatable.rb

Instance Method Summary collapse

Instance Method Details

#create(attributes = nil, &block) ⇒ Document+

Create a new document. This will instantiate a new document and insert it in a single call. Will always return the document whether save passed or not.

Examples:

Create a new document.

Person.create(:title => "Mr")

Create multiple new documents.

Person.create({ title: "Mr" }, { title: "Mrs" })

Parameters:

  • attributes (Hash, Array) (defaults to: nil)

    The attributes to create with, or an Array of multiple attributes for multiple documents.

Returns:



137
138
139
140
141
142
143
144
145
146
147
# File 'build/mongoid-master/lib/mongoid/persistable/creatable.rb', line 137

def create(attributes = nil, &block)
  _creating do
    if attributes.is_a?(::Array)
      attributes.map { |attrs| create(attrs, &block) }
    else
      doc = new(attributes, &block)
      doc.save
      doc
    end
  end
end

#create!(attributes = nil, &block) ⇒ Document+

Create a new document. This will instantiate a new document and insert it in a single call. Will always return the document whether save passed or not, and if validation fails an error will be raise.

Examples:

Create a new document.

Person.create!(:title => "Mr")

Create multiple new documents.

Person.create!({ title: "Mr" }, { title: "Mrs" })

Parameters:

  • attributes (Hash, Array) (defaults to: nil)

    The attributes to create with, or an Array of multiple attributes for multiple documents.

Returns:



164
165
166
167
168
169
170
171
172
173
174
175
# File 'build/mongoid-master/lib/mongoid/persistable/creatable.rb', line 164

def create!(attributes = nil, &block)
  _creating do
    if attributes.is_a?(::Array)
      attributes.map { |attrs| create!(attrs, &block) }
    else
      doc = new(attributes, &block)
      doc.fail_due_to_validation! unless doc.insert.errors.empty?
      doc.fail_due_to_callback!(:create!) if doc.new_record?
      doc
    end
  end
end