推荐工具
RoboMongo
推荐书目
50 Tips and Tricks for MongoDB Developers
Related Blogs
Snail in a Turtleneck
Vegetable
V2EX  ›  MongoDB

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

  •  
  •   Vegetable · Jul 11, 2019 · 9669 views
    This topic created in 2510 days ago, the information mentioned may be changed or developed.

    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 replies    2019-07-12 09:45:06 +08:00
    anakinsky
        1
    anakinsky  
       Jul 11, 2019
    Spring Data MongoTemplate
    zhybb2010
        2
    zhybb2010  
       Jul 11, 2019
    +1
    andylsr
        4
    andylsr  
       Jul 11, 2019 via Android
    自己封装一下。。。
    Vegetable
        5
    Vegetable  
    OP
       Jul 11, 2019
    @wizzer
    @anakinsky

    java 大法好,这样起码不用自己设计了,抄一个差不多的到项目里来也好.
    itskingname
        6
    itskingname  
       Jul 11, 2019 via iPhone
    Python 我自己写了一个。
    mmdsun
        7
    mmdsun  
       Jul 11, 2019 via Android   ❤️ 1
    studio 3T 可以写 SQL 它自动生成 MongoDB 查询语句
    mmdsun
        8
    mmdsun  
       Jul 11, 2019 via Android
    @mmdsun 语言包括 Java,Python 都支持。
    leafiy
        9
    leafiy  
       Jul 11, 2019
    我在做的是你的 3-5 倍长度,细粒拆分一下,做一个配置文件,起码看起来舒服多了
    460881773
        10
    460881773  
       Jul 11, 2019
    一楼加一
    qile1
        11
    qile1  
       Jul 12, 2019 via Android
    redash 里面有编辑 sql 语句,可以参考下,我没细研究
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2043 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 45ms · UTC 16:13 · PVG 00:13 · LAX 09:13 · JFK 12:13
    ♥ Do have faith in what you're doing.