Fatal error: Uncaught exception 'MongoException' with message 'current batch size is too large: 48000077, max: 48000000'
It would have been better to have seen a not in the manual.
(PECL mongo >=0.9.0)
MongoCollection::batchInsert — Inserts multiple documents into this collection
a
An array of arrays or objects. If any objects are used, they may not have protected or private properties.
Notă:
If the documents to insert do not have an
_id
key or property, a new MongoId instance will be created and assigned to it. See MongoCollection::insert() for additional information on this behavior.
options
An array of options for the batch of insert operations. Currently available options include:
"continueOnError"
Boolean, defaults to false
. If set, the database will not stop
processing a bulk insert if one fails (eg due to duplicate IDs).
This makes bulk insert behave similarly to a series of single
inserts, except that calling MongoDB::lastError()
will have an error set if any insert fails, not just the last one.
If multiple errors occur, only the most recent will be reported by
MongoDB::lastError().
Notă:
Please note that
continueOnError
affects errors on the database side only. If you try to insert a document that has errors (for example it contains a key with an empty name), then the document is not even transferred to the database as the driver detects this error and bails out.continueOnError
has no effect on errors detected in the documents by the driver.
"fsync"
O valoare boolean-ă, valoarea
implicită este false
. Dacă jurnalizarea e activată, ea funcționează exact ca
"j"
. Dacă jurnalizarea nu este acticvată, atunci se forțează
sincronizarea pe disc a operațiunii de inserare înainte de a întoarce succes.
Dacă are valoarea true
, se presupune efectuarea
unei inserări cu confirmare și setarea w
va fi modificată în
0
.
Notă: Dacă jurnalizarea este activată, utilizatorii sunt încurajați să utilizeze opțiunea
"j"
în loc de"fsync"
. Nu utilizați"fsync"
și"j"
simultan, deoarece aceasta va rezulta în eroare.
"j"
O valoare boolean-ă, cu valoarea
implicită false
. Forțează sincronizarea cu jurnalul a operațiunii de inserare,
înainte de a întoarce succes. Dacă are valoarea true
, se presupune efectuarea
unei inserări cu confirmare și setarea w
va fi modificată în
0
.
Notă: Dacă această opțiune e utilizată, iar jurnalizarea e dezactivată, MongoDB 2.6+ va emite o eroare și înscrierea va eșua; versiunile mai vechi ale serverului pur și simplu vor ignora opțiunea.
"socketTimeoutMS"
Această opțiune specifică
limita de timp în milisecunde pentru comunicarea prin socket. Dacă serverul nu
răspunde în limita intervalului de timp, se va emite o
MongoCursorTimeoutException și nu va fi nici o posibilitate
de a determina dacă serverul a efectuat înscrierea, sau nu. Valoarea
-1
poate fi specificată pentru a suspenda pentru o perioadă
nedefinită. Valoarea implicită pentru MongoClient este
30000
(30 secunde).
"w"
Vedeți
WriteConcerns. Valoarea implicită
pentru MongoClient este 1
.
"wTimeoutMS"
Această opțiune specifică
limita de timp în milisecunde pentru confirmarea
write concern. Aceasta este aplicabilă
doar atunci când "w"
este mai mare decât 1
,
deoarece expirarea timpului ține de replicare. Dacă "write concern" nu este
satisfăcută în limita intervalului de timp, se va emite o MongoCursorException.
Valoarea 0
poate fi specificată pentru a suspenda pentru o
perioadă nedefinită. Valoarea implicită pentru MongoClient
este 10000
(zece secunde).
The following options are deprecated and should no longer be used:
"safe"
Învechită. Utilizați opțiunea
WriteConcern
w
.
"timeout"
Un pseudonim învechit pentru "socketTimeoutMS"
.
"wtimeout"
Un pseudonim învechit pentru
"wTimeoutMS"
.
If the w
parameter is set to acknowledge the write,
returns an associative array with the status of the inserts ("ok") and any
error that may have occurred ("err"). Otherwise, returns true
if the
batch insert was successfully sent, false
otherwise.
Throws MongoException if any inserted documents are empty or if they contains zero-length keys. Attempting to insert an object with protected and private properties will cause a zero-length key error.
Generează o excepție MongoCursorException dacă opțiunea
"w"
este stabilită și înscrierea eșuează.
Generează o excepție
MongoCursorTimeoutException dacă opțiunea
"w"
este stabilită la o valoare mai mare decât unu și
operațiunea durează mai mult de MongoCursor::$timeout
milisecunde. Aceasta nu va întrerupe operațiunea pe server, este un timeout de
partea clientului. Operațiunea din MongoCollection::$wtimeout
este în milisecunde.
Versiune | Descriere |
---|---|
PECL mongo 1.5.0 |
Added the
Added the
Emits |
PECL mongo 1.3.4 | Added "wtimeout" option. |
PECL mongo 1.3.0 | Added "w" option. |
PECL mongo 1.2.7 | Added "continueOnError" option. |
PECL mongo 1.0.9 |
Added ability to pass integers to the
Added |
PECL mongo 1.0.5 | Added options parameter. |
Example #1 MongoCollection::batchInsert() example
Batch insertion is a quick way to add many elements to the database at once
<?php
$users = array();
for ($i = 0; $i<100; $i++) {
$users[] = array('username' => 'user'.$i, 'i' => $i);
}
$mongo = new MongoClient();
$collection = $mongo->my_db->users;
$collection->drop();
$collection->batchInsert($users);
foreach ($users as $user) {
echo $user['_id']."\n"; // populated with instanceof MongoId
}
$users = $collection->find()->sort(array('i' => 1));
foreach ($users as $user) {
var_dump($user['username']);
}
?>
Exemplul de mai sus va afișa ceva similar cu:
4bf43ac68ead0e1971000000 4bf43ac68ead0e1971010000 4bf43ac68ead0e1971020000 ... string(5) "user1" string(5) "user2" string(5) "user3" ...
Example #2 MongoCollection::batchInsert() example with ignoring errors
<?php
$con = new Mongo;
$db = $con->demo;
$doc1 = array(
'_id' => new MongoId('4cb4ab6d7addf98506010001'),
'id' => 1,
'desc' => "ONE",
);
$doc2 = array(
'_id' => new MongoId('4cb4ab6d7addf98506010002'),
'id' => 2,
'desc' => "TWO",
);
$doc3 = array(
'_id' => new MongoId('4cb4ab6d7addf98506010002'), // same _id as above
'id' => 3,
'desc' => "THREE",
);
$doc4 = array(
'_id' => new MongoId('4cb4ab6d7addf98506010004'),
'id' => 4,
'desc' => "FOUR",
);
$c = $db->selectCollection('c');
$c->batchInsert(
array($doc1, $doc2, $doc3, $doc4),
array('continueOnError' => true)
);
$docs = $c->find();
foreach ($docs as $doc) {
var_dump($doc['desc']);
}
?>
Exemplul de mai sus va afișa ceva similar cu:
string(3) "ONE" string(3) "TWO" string(4) "FOUR"
Fatal error: Uncaught exception 'MongoException' with message 'current batch size is too large: 48000077, max: 48000000'
It would have been better to have seen a not in the manual.