V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐工具
RoboMongo
推荐书目
50 Tips and Tricks for MongoDB Developers
Related Blogs
Snail in a Turtleneck
lzt163
V2EX  ›  MongoDB

关于mongo两种方式的效率

  •  
  •   lzt163 · 2014-01-30 14:48:17 +08:00 · 4689 次点击
    这是一个创建于 3740 天前的主题,其中的信息可能已经有所发展或是发生改变。
    想请教个问题
    两个Collection 如
    A: {_id:..., pid:1000}
    B: {_id:..., rid:10000, pid:1000, flag: 1}

    我需要的是在A中查到一个集合
    并且需要用A的pid在B中统计flag为1或0的记录的数量
    B中的读写频繁 但一般只做插入
    A大概1W的记录 B可能会上100W的记录

    两种方法
    1 在A中加统计数量的字段count B中有变话则修改A中count
    2 像上面所说用每条A查询B.find(...).count()

    哪一种会效率高一些 并且缓存空间不会占用太大
    6 条回复    1970-01-01 08:00:00 +08:00
    czheo
        1
    czheo  
       2014-01-30 15:56:58 +08:00
    1吧 count快不了
    huoxiaochai
        2
    huoxiaochai  
       2014-01-30 20:01:57 +08:00
    慎用mongo,天坑地坑人坑
    breeswish
        3
    breeswish  
       2014-01-31 00:15:56 +08:00   ❤️ 1
    如果B规模那么大当然是对A使用$inc来记录count效率高多了咯,虽然B可以加索引但是count效率很大程度上取决于数据(不过这样的话A不就是个cache么…
    lzt163
        4
    lzt163  
    OP
       2014-01-31 00:29:10 +08:00
    @breeswish 恍然悟到了什么 感谢
    xiaoyukid
        5
    xiaoyukid  
       2014-02-01 15:26:38 +08:00 via Android
    @lzt163 求分享
    lzt163
        6
    lzt163  
    OP
       2014-02-05 20:05:42 +08:00
    @xiaoyukid 是我太蠢了 忘记了$inc 这个好东西...
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2693 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 00:31 · PVG 08:31 · LAX 17:31 · JFK 20:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.