$ push in mongo

时间:2016-01-11 20:01:23

标签: c mongodb mongodb-query mongo-c-driver

我遇到了问题而且我不确定如何修复它。你能提供的任何帮助都会很棒,我确信这是一件令我愚蠢的事情。 :)

我正在尝试将一些项目推送到名为" subscribed_tribes"的数组中。在推送之前,这是我的文档:

{ 
"_id" : ObjectId("5693fc1f6890f14daa0e26e1"), 
"password" : "7CAE......", 
"salt" : "748D...", 
"created" : ISODate("2016-01-11T19:01:51.000+0000"), 
"display_name" : "2686....", 
"my_tribes" : "", 
"subscribed_tribes" : ""
}

当我运行以下c代码时,没有任何事情发生(没有变化)。

        collection = mongoc_client_get_collection (client, "STribe", "users");

        query = bson_new ();
        bson_oid_t oid;
        char *techSupportID = "5693c0196890f159c1741bb1";
        bson_oid_init_from_string (&oid, techSupportID);
        query = BCON_NEW ("_id", BCON_OID(&oid));

        // Find the document
        cursor = mongoc_collection_find (collection, MONGOC_QUERY_NONE, 0, 0, 0, query, NULL, NULL);

        update = bson_new ();
        //BSON_APPEND_UTF8 (update, "testing", "blah");
        //mongoc_collection_update (collection, MONGOC_UPDATE_NONE, query, update, NULL, &error);


        // Assemble query
        update = BCON_NEW ("$push", 
            "{", 
                "subscribed_tribes", 
                    "{", 
                        "tribe_id",     BCON_UTF8 (tribe_id), 
                        "tribe_key",  BCON_UTF8 (passphrase), 
                    "}", 
            "}");
        mongoc_collection_update (collection, MONGOC_UPDATE_NONE, query, update, NULL, &error);

如果我取消注释两行代码(bson_append和mongc_collection_update),那么整个文档将被覆盖并替换为:

{ 
"_id" : ObjectId("5693c0196890f159c1741bb1"), 
"testing" : "blah", 
"subscribed_tribes" : [
    {
        "tribe_id" : "5624200d4bacd3940b8b2d62", 
        "tribe_key" : "27D719EDC7A59...."
    }
]
}

为什么原始代码没有正确地将数组项添加到subscribed_tribes中的任何想法?其次,为什么包含未注释的行会覆盖整个文档?

我再次肯定我做了一些愚蠢的事,但我不确定是什么。

1 个答案:

答案 0 :(得分:0)

subscribed_tribes目前是一个字符串,而不是一个数组。这就是为什么你不能使用$push的原因。

如果您检查已填充的error结果,则应收到有关该结果的错误消息。

因此,$push要使您的文档看起来像这样:

{ 
"_id" : ObjectId("5693fc1f6890f14daa0e26e1"), 
"password" : "7CAE......", 
"salt" : "748D...", 
"created" : ISODate("2016-01-11T19:01:51.000+0000"), 
"display_name" : "2686....", 
"my_tribes" : "", 
"subscribed_tribes" : []
}