class Mongo::Operation::Write::Insert

A MongoDB insert operation.

@note If a server with version >= 2.5.5 is being used, a write command

operation will be created and sent instead.

@example Create the new insert operation.

Write::Insert.new({
  :documents => [{ :foo => 1 }],
  :db_name => 'test',
  :coll_name => 'test_coll',
  :write_concern => write_concern
})

Initialization:

param [ Hash ] spec The specifications for the insert.

option spec :documents [ Array ] The documents to insert.
option spec :db_name [ String ] The name of the database.
option spec :coll_name [ String ] The name of the collection.
option spec :write_concern [ Mongo::WriteConcern ] The write concern.
option spec :options [ Hash ] Options for the command, if it ends up being a
  write command.

@since 2.0.0

Private Instance Methods

execute_message(server) click to toggle source
# File lib/mongo/operation/write/insert.rb, line 61
def execute_message(server)
  server.with_connection do |connection|
    Result.new(connection.dispatch([ message(server), gle ].compact), @ids).validate!
  end
end
execute_write_command(server) click to toggle source
# File lib/mongo/operation/write/insert.rb, line 53
def execute_write_command(server)
  command_spec = spec.merge(:documents => ensure_ids(documents))
  result = Result.new(Command::Insert.new(command_spec).execute(server), @ids)
  server.update_cluster_time(result)
  session.process(result) if session
  result.validate!
end
message(server) click to toggle source
# File lib/mongo/operation/write/insert.rb, line 67
def message(server)
  opts = !!options[:continue_on_error] ? { :flags => [:continue_on_error] } : {}
  Protocol::Insert.new(db_name, coll_name, ensure_ids(documents), opts)
end