Как добавить новый атрибут к тысячам документов Mongodb в исполнении yii2?Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Как добавить новый атрибут к тысячам документов Mongodb в исполнении yii2?

Сообщение Anonymous »

У меня есть php + yii2 + mongodb, работающий на Linux в виртуальном боксе (10 ядер, 12 ГБ ОЗУ). yii2-mongodb установлен. У меня есть CSV-файл, содержащий более 100 000 записей в двух столбцах: пользовательский идентификатор (не _id) и число. Я хотел бы добавить номер к документам в коллекции в mongodb, где пользовательский идентификатор соответствует документу. Я пробовал несколько разных подходов, например: 1. $collection->update() в цикле while(fgetcsv), 2. пытался создать массив в while(), например:

Код: Выделить всё

$command = $conn->createCommand();

while(fgetcsv...) {
$command->addUpdate(['identifier' => $csvrow[0]], ['number' => $csvrow[1]]);
}

$command->executeBatch('collection');
работает, но ужасно медленно. 10-20 записей в секунду. Я попытался добавить индекс text к пользовательскому идентификатору в компасе mongodb (у меня есть 1 (по возрастанию), -1 (по убыванию), 2dsphere и текст), но не получил прироста производительности. Что мне не хватает?

Подробнее здесь: https://stackoverflow.com/questions/786 ... performant
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»