(mongodb >=0.2.0)
MongoDB\Driver\Manager::executeInsert — Convenience method for a single insert operation
$namespace
, array|object $document
[, MongoDB\Driver\WriteConcern $writeConcern
] )Convenience method to execute a MongoDB\Driver\BulkWrite with only one insert operation.
namespace
完全修飾形式の名前空間 (databaseName.collectionName)。
document
The document to insert.
writeConcern
オプションで、MongoDB\Driver\WriteConcern を指定します。省略した場合のデフォルトは、MongoDB Connection URI で設定したものとなります。
成功した場合に MongoDB\Driver\WriteResult を返します。失敗した場合に例外 (MongoDB\Driver\Exception のインスタンス) をスローします。
例1 MongoDB\Driver\Manager::executeInsert() example
<?php
$document = array(
"title" => "mongodb",
);
$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 100);
$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");
$result = $manager->executeInsert("mydb.collection", $document, $writeConcern);
printf("Inserted %d document(s)\n", $result->getInsertedCount());
/* If the WriteConcern could not be fulfilled */
if ($writeConcernError = $result->getWriteConcernError()) {
printf("%s (%d): %s\n", $writeConcernError->getMessage(), $writeConcernError->getCode(), var_export($writeConcernError->getInfo(), true));
}
/* If the write could not happen at all */
foreach ($result->getWriteErrors() as $writeError) {
printf("%s (%d)\n", $writeError->getMessage(), $writeError->getCode());
}
?>
上の例の出力は、 たとえば以下のようになります。
Inserted 1 document(s)
注意:
書き込みが失敗した場合は、 MongoDB\Driver\WriteResult::getWriteErrors() の配列内には MongoDB\Driver\WriteError がひとつだけしか含まれません。 また MongoDB\Driver\WriteError::getIndex() は常に 0 (バッチ内におけるこの操作のインデックス) となります。