(mongodb >=2.1.0)
MongoDB\Driver\BulkWriteCommand::__construct — Créer une nouvelle BulkWriteCommand
Construit une nouvelle MongoDB\Driver\BulkWriteCommand, qui peut être utilisée pour effectuer de nombreuses opération d'insertions, mises à jour et suppression sur plusieurs collections dans une seule requête à l'aide de la commande » bulkWrite introduite dans MongoDB 8.0. Cela diffère de MongoDB\Driver\BulkWrite, qui est supporté par toutes les versions du serveur mais limité à une seule collection.
Après toutes les opérations d'écriture ont été ajoutées, cet objet peut être exécuté avec MongoDB\Driver\Manager::executeBulkWriteCommand().
options
(array)
Option | Type | Description | Défaut |
---|---|---|---|
bypassDocumentValidation | bool |
Si |
false |
comment | mixed |
Un commentaire arbitraire pour aider à tracer l'opération à travers le profileur de base de données, la sortie currentOp et les journaux. |
|
let | array|object |
Dictionnaire des noms et des valeurs des paramètres. Les valeurs doivent être des constantes ou des expressions fermées qui ne font pas référence aux champs du document. Les paramètres peuvent ensuite être accédés en tant que variables dans un contexte d'expression agrégée (par exemple Cette option est disponible dans MongoDB 5.0+ et entraînera une exception au moment de l'exécution si elle est spécifiée pour une version antérieure du serveur. |
|
ordered | bool |
Si les opérations dans cette écriture groupée doivent être exécutées dans
l'ordre dans lequel elles ont été spécifiées. Si |
true |
verboseResults | bool |
Si les détails des résultats de chaque opération réussie doivent être inclus dans le résultat dans la MongoDB\Driver\BulkWriteCommandResult retournée. |
false |
Exemple #1 Exemple de MongoDB\Driver\BulkWriteCommand::__construct()
<?php
$manager = new MongoDB\Driver\Manager;
$bulk = new MongoDB\Driver\BulkWriteCommand;
// Supprime les documents de deux collections
$bulk->deleteMany('db.coll_one', []);
$bulk->deleteMany('db.coll_two', []);
// Ajoute les documents de deux collections
$bulk->insertOne('db.coll_one', ['_id' => 1]);
$bulk->insertOne('db.coll_two', ['_id' => 2]);
$bulk->insertOne('db.coll_two', ['_id' => 3]);
// Modifie un document dans "coll_one"
$bulk->updateOne('db.coll_one', ['_id' => 1], ['$set' => ['x' => 1]]);
$result = $manager->executeBulkWriteCommand($bulk);
printf("%d document(s) ont été inséré(s)\n", $result->getInsertedCount());
printf("%d document(s) ont été mise à jour(s)\n", $result->getModifiedCount());
?>
L'exemple ci-dessus va afficher :
3 document(s) ont été inséré(s) 1 document(s) ont été mise à jour(s)