国产成人AV无码一二三区,少女1到100集,国产精品久久久久精品综合紧,巜公妇之诱感肉欲HD在线播放

文章 > MongoDB > mongodb一般怎么用

mongodb一般怎么用

MongoDB

头像

silencement

2020-01-11 13:08:013479浏览 · 0收藏 · 0评论

mongodb众所周知不支持事务,所以需要强事务的业务根本不能考虑mongodb。

mongodb的优势就是文档存储:

1. 业务经常变动,需要不时的添加字段,那么mongodb比较适合,关系型数据库添加字段的复杂度也还好

2. 嵌套文档,业务数据比较复杂,适合嵌套文档式存储,那么mongodb非常合适,这个关系型数据库比较难搞,虽然MySQL和pg也有文档存储,但MySQL的不成熟,pg毕竟现在生产中使用还是偏少,个人也不了解,这里不谈。但这不仅仅这一点优势,具体下面会细说。

3. upsert支持,查询速度也不慢

4. 高可用的副本集支持

5. 查询语法非常丰富,嵌套文档查询功能非常强大,不是重度用户可能不能理解

推荐学习《python教程

下面说说一个具体的使用事例:

项目的一条数据在10kb左右,如果使用关系型数据库那么需要将这条数据拆分成大概几百条左右,建造多个表,设计较复杂,这种数据大概在一百万条左右,想想拆分后在十几亿的数据量就可怕。打平后的数据什么DB也都可以拿下,只是一百万变十几亿比较恐怖而已。

如果采用MySQL存储,每次查询需要使用外键查询多个表,从这些表中拉取数据,性能肯定要下降很多,比不上只在一个表查询,而且只拉取少两个数量级的数据。查询也还好,业务允许可以对结果做缓存,放到redis里去。

但是重点来了,需求要增量更新部分数据,这时候需要更新多个表,根本没法做到原子性(注意事务不是原子操作),当然也可以使用cas等技术补偿,达到最终一致性。但使用mongodb存储只需要update一条数据,对相应的嵌套文档中内容更新,可以做到原子性,是不是很方便?

具体说说该项目的难点,查询无法使用缓存,可能会很吃惊,但是业务决定了确实做不了,而且增量更新的量达到上万的QPS,如果不能保证原子性想想多么可怕!

所以mongodb在这里帮了大忙,关系型数据库解决不了这个难题。

有人可能要问,mongodb没有事务,上游数据写入也会有问题,你不可能所有数据都存一个表吧?

当然不是的,我们mongodb里的数据是从MySQL中清洗出来存到mongodb中的,mongodb只做单点的业务需求,综合的数据还是在MySQL中。

此项目我们用了上百个副本集,保证系统的高可用,这些副本集配置只要一条shell就搞定,如果用MySQL的主从不知道怎么配(我自己不懂),估计DBA得忙死,而该项目完全不需要也没用到DBA。

说了这么多mongo的优点,也说说他的缺点:

1. 查询优化器和MySQL没法比

2. 不支持reload,只能冷重启,初始化配置的时候比较麻烦

3. 没有事务,不敢存储第一手数据,多用来做备份数据的存储

mongodb可以做很多事情,取决于你脑洞,性能不差,存一些相对不重要的数据,mongodb嵌套文档功能强大,多看看官方文档挖掘挖掘有用信息,每次都能发现惊喜。

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

《完美邻居2》电影在线观看| 局长边摸边吃奶边做爰| 狗锁女人全集免费播放| 20厘米能插到肚子吗| 成全在线观看免费完整版的| 游泳教练在水里含我奶| 一前一后三个人一起的游戏规则| 久久久久精品国产亚洲AV嘛盔豆| 《性爽2》电影| 一路向西在线播放| 舌头伸进去添的我爽高潮| 妈妈你真棒里面的插曲叫什么 | 苍老师巅峰电影在线观看| 图书馆挺进她腿间湿润漫画| 跳D开到最大C死我| 《办公室高潮秘书2》| 女性扒开大腿内侧小肚子痒| 来吧儿子妈妈是纯还是混| 麻花传剧MV无痕免费观看姐弟| 翁吻乳婷婷小玲21章| 每日大赛 反差吃瓜爆料合集视频| 蜜桃成熟3D| 《明明说好要带避孕套了》中文版 | 18岁的少女与狗高清电视剧| 美国A片巜禁忌9| 老翁玩嫩媳| 妈妈的新男友| 露胸透明睡衣| 一边吃奶一边做边爱会得白血病吗| 97在线观看免费高清电视剧狂飙| 50章厨房激情双开| 韩国电影火热的邻居高清完整版免.| 男人问你舒服吗出于什么心理| 生殖瑜伽| 老婆同意了别人轮流联系我| 国精产品一品二品国精HTC| 《熟妇的荡欲》HD中字| 《老板娘2》完整版| 两个奶头被吃得又翘又肿特别疼| 暴躁少女CSGO免费观看| 爸爸的擎天柱让我看第二集