我开发了一款 Python 版的 mybatis ORM - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
ht201908001
V2EX    分享创造

我开发了一款 Python 版的 mybatis ORM

  •  
  •   ht201908001 2024-12-08 16:57:16 +08:00 1943 次点击
    这是一个创建于 382 天前的主题,其中的信息可能已经有所发展或是发生改变。
    最近在学习 python web 开发,一直没找到类似 mybatis 的半自动化 ORM ,所以开发了一个,
    地址在 https://github.com/ralgond/mybatis-py

    主要功能如下:
    1 、半自动化的 ORM ;
    2 、支持像 mybatis 那样的动态 SQL ;
    3 、支持类似 mybatis 注解的装饰器;
    4 、支持 LRU 缓存,支持缓存过期机制;
    5 、尽可能地使用 Prepared statement ,避免 SQL 字符串拼接,能有效地防止 SQL 注入;
    6 、预防大对象机制,避免 OOM 。

    未来的开发方向是支持多种数据库。


    如果你有什么需求和想法,尽管提出给我,如有必要我会尽最大努力去实现,谢谢大家!
    10 条回复    2024-12-19 15:23:53 +08:00
    hefish
        1
    hefish  
       2024-12-08 17:54:25 +08:00
    看着挺高级的。
    Kite6
        2
    Kite6  
       2024-12-08 18:15:27 +08:00 via Android
    和 sqlmodel 相比有什么优势吗
    sagaxu
        3
    sagaxu  
       2024-12-08 18:24:30 +08:00
    相比 sqlalchemy 或者 peewee 有什么改进?

    mybatis 也就国内比较热衷,国外主流还是 JPA ,连 JOOQ 都比 mybatis 火
    ht201908001
        4
    ht201908001  
    OP
       2024-12-08 19:17:41 +08:00
    @Kite6 mybatis-py 主要优势是能手写 SQL ,可以将简单的 SQL 写在装饰器上,也可以在 xml 文件中编写复杂的 SQL 。感谢你提供 sqlmodel 这个选项,我刚好可以从它那汲取一些特性,让 mybatis-py 更好用。
    ht201908001
        5
    ht201908001  
    OP
       2024-12-08 19:22:24 +08:00
    @sagaxu mybatis-py 和两者的关系应该就是像 mybatis 和 hibernate 的关系一样,mybatis-py 适合对 SQL 控制有较高要求的场景。
    sagaxu
        6
    sagaxu  
       2024-12-09 09:33:28 +08:00
    @ht201908001 跟 hibernate 对应的是 sqlalchemy ORM 这一层,但这一层可以完全不用,直接用 sqlalchemy CORE ,它只做连接池,表结构元数据,SQL 生成,不同 dialect 适配等基础工作。可以当作是支持运行时反射数据库分析表结构的 JOOQ 。

    从 SQL Builder 层面看,大家都是用不同的 DSL 拼 SQL ,如果都约定好拼 SQL 的代码放在规定的地方,且只做拼 SQL 的事情,用哪个 DSL 拼都不会有太大差别。
    R4rvZ6agNVWr56V0
        7
    R4rvZ6agNVWr56V0  
       2024-12-09 09:58:42 +08:00
    Non-Pythonic
    tairan2006
        8
    tairan2006  
       2024-12-09 16:09:34 +08:00
    对于动态语言搞这个其实不太合适,ruby 更灵活呢。
    zzz2570389155
        9
    zzz2570389155  
       2024-12-19 15:21:01 +08:00
    可以添加一个直接查询 sql 的接口或者支持下 jinja2 模板
    zzz2570389155
        10
    zzz2570389155  
       2024-12-19 15:23:53 +08:00
    老哥,能不能建个交流群,mybatis-py 这想法挺好的
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2749 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 43ms UTC 14:58 PVG 22:58 LAX 06:58 JFK 09:58
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86