Обновление MongoDB заменяет документ - PullRequest
1 голос
/ 09 июля 2011

Я пытаюсь обновить документ MongoDB через PHP.Моя проблема в том, что данные документов удаляются при обновлении, поэтому другие данные, кроме того, что я обновляю, исчезают.

Перед обновлением документ выглядит следующим образом:

{
    "_id": {
        "$oid": "4e178b45419866350f000001"
    },
    "Twitter": {
        "_id": {
            "$oid": "4e178b45419866350f000000"
        },
        "created": {
            "$date": "2011-07-08T22:57:09Z"
        },
        "userid": "5552362"
    },
    "created": {
        "$date": "2011-07-08T22:57:09Z"
    }
}

Вот какЯ обновляю:

    $r = $Profile->update(
        array('Twitter._id' => new MongoId($profile['_id'])),
        array(
            '$set' => array(
                'Twitter' => array(
                    'name' => $user['name'],
                    'username' => $user['screen_name'],
                    'url' => $user['url'],
                    'modified' => new MongoDate()
                )
            )
        ),
        array('safe' => true)
    );
    debug($r); 

1 Ответ

4 голосов
/ 09 июля 2011

Я думаю, вы хотите такое обновление:

$Profile->update(
    array('Twitter.userid' => $user['id']),
    array(
        '$set' => array(
            'Twitter.name' => $user['name'],
            'Twitter.username' => $user['screen_name'],
            'Twitter.url' => $user['url'],
            'Twitter.modified' => new MongoDate()
        )
    ),
    array('multiple' => true)
);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...