• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 79  文章 - 58  trackbacks - 0
            <2007年5月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(9)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊(cè)

            搜索

            •  

            積分與排名

            • 積分 - 296056
            • 排名 - 87

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            1、實(shí)現(xiàn)原理

            為了實(shí)現(xiàn)自增ID,,需要引入專門計(jì)算id的Collection。
            該collection中存放的記錄格式類似如下:
            {'_id': 1,  'current_id_value':1} , 
            其中current_id_value對(duì)應(yīng)著當(dāng)前最大id值+1,每次需要獲取一個(gè)ID時(shí),需要先到該collection查詢對(duì)應(yīng)的currentIdValue 值并把這個(gè)值+1
            mongodb提供了findAndModify接口,并且是線程安全的,做到查詢并加1的原子操作。

            2、代碼如下

            int64_t GetID()
            {
                int64_t ret = -1;
                
                mongoc_collection_t *pCountCollection = mongoc_client_get_collection(m_pClient, "test_db", "id_generator");
                
                bson_error_t error;
                bson_t *doc = bson_new();

                bson_t child;
                bson_append_document_begin(doc, "$inc", -1, &child);
                BSON_APPEND_INT64(&child, "current_id_value", 1);
                bson_append_document_end(doc, &child);

                bson_t query;
                bson_init(&query);
                BSON_APPEND_INT64(&query, "_id", 1);

                bson_t reply;
                bool r = mongoc_collection_find_and_modify(pCountCollection,
                    &query,
                    NULL,
                    doc,
                    NULL,
                    false,
                    true,
                    true,
                    &reply,
                    &error);
                if (!r)
                {
                    cout << "GetID Failure: " << error.message;
                }
                else
                {
                    bson_iter_t iter;
                    bson_iter_init(&iter, &reply);
                    if (bson_iter_find(&iter, "value"))
                    {
                        const uint8_t *buf;
                        uint32_t len;
                        bson_iter_document(&iter, &len, &buf);
                        bson_t rec;
                        bson_init_static(&rec, buf, len);

                        bson_iter_init(&iter, &rec);
                        if (bson_iter_find(&iter, "current_id_value"))
                        {
                            ret = bson_iter_int64(&iter);
                        }
                        bson_destroy(&rec);
                    }
                }

                bson_destroy(&query);
                bson_destroy(&reply);
                bson_destroy(doc);

                return ret;
            }
            posted on 2014-09-27 16:23 merlinfang 閱讀(3912) 評(píng)論(0)  編輯 收藏 引用 所屬分類: mongodb
            久久这里只有精品久久| 青青国产成人久久91网| 久久天天躁狠狠躁夜夜2020一| 久久精品中文字幕大胸| 人人狠狠综合久久88成人| 麻豆精品久久久一区二区| 精品多毛少妇人妻AV免费久久| 久久99国产亚洲高清观看首页| 欧美精品一区二区久久| 久久人妻少妇嫩草AV无码专区| 色综合久久88色综合天天 | 日韩av无码久久精品免费| 久久亚洲精品视频| 99久久精品国产一区二区| 国产精品伊人久久伊人电影| 色综合久久久久无码专区 | WWW婷婷AV久久久影片| 久久久久久av无码免费看大片| 精品国产乱码久久久久久郑州公司 | 久久天天躁狠狠躁夜夜不卡| 久久精品国产亚洲av日韩| 久久精品国产99国产精品导航 | 久久久久99精品成人片直播| 中文字幕精品久久| 91久久精品国产成人久久| 国产精品一久久香蕉国产线看观看| 怡红院日本一道日本久久| 久久天天躁狠狠躁夜夜躁2O2O| 亚洲精品无码久久不卡| 婷婷久久综合九色综合绿巨人| 四虎国产精品免费久久5151| 久久国产精品久久精品国产| 久久精品a亚洲国产v高清不卡| 久久亚洲精品中文字幕| 亚洲成色www久久网站夜月| 无码AV中文字幕久久专区| 国产亚洲精品久久久久秋霞| 久久久www免费人成精品| 99久久精品国产一区二区| 久久青青草原精品国产| 久久综合欧美成人|