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

又臭又长的 Mongodb 聚合语句该怎么管理

  •  
  •   Vegetable · 150 天前 · 7143 次点击
    这是一个创建于 150 天前的主题,其中的信息可能已经有所发展或是发生改变。

    MongoDB 的聚合语句有时候会写的比较长,语句本身信噪比比较低,有很多的符号,比如{}[]:""$,写在代码里经常就是一大片.看起来眼睛都花了.如果不写在代码里又觉得不合适.

    今天在想为什么没有一个类似于这种的框架呢:

    class Aggregate:
        """ Do some magic """
    a = Aggregate()
    a.match(time={"$gte": "2019"})
    a.project(_id=0)
    a.sort(time=-1)
    
    # a.pipeline
    # [{"$match": {"time": "$gte": "2019"}}, {"$project": {"_id": 0}}, {"sort": {"time": -1}}]
    
    
    

    感觉这样在代码里层次感能更好一点,其实就是一个类似 ORM 自动生成 SQL.稍微找了一下,好像没有现成的轮子,难道别人都不会被类似的问题困扰吗?

    11 回复  |  直到 2019-07-12 09:45:06 +08:00
        1
    anakinsky   150 天前
    Spring Data MongoTemplate
        2
    zhybb2010   150 天前
    +1
        4
    andylsr   150 天前 via Android
    自己封装一下。。。
        5
    Vegetable   150 天前
    @wizzer
    @anakinsky

    java 大法好,这样起码不用自己设计了,抄一个差不多的到项目里来也好.
        6
    itskingname   150 天前 via iPhone
    Python 我自己写了一个。
        7
    mmdsun   150 天前 via Android   ♥ 1
    studio 3T 可以写 SQL 它自动生成 MongoDB 查询语句
        8
    mmdsun   150 天前 via Android
    @mmdsun 语言包括 Java,Python 都支持。
        9
    leafiy   150 天前
    我在做的是你的 3-5 倍长度,细粒拆分一下,做一个配置文件,起码看起来舒服多了
        10
    460881773   150 天前
    一楼加一
        11
    qile1   150 天前 via Android
    redash 里面有编辑 sql 语句,可以参考下,我没细研究
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4444 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 24ms · UTC 02:25 · PVG 10:25 · LAX 18:25 · JFK 21:25
    ♥ Do have faith in what you're doing.