请教 Go:ent ORM 框架,分表如何操作呢? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
antxiaoye

请教 Go:ent ORM 框架,分表如何操作呢?

  •  
  •   antxiaoye Nov 19, 2021 4183 views
    This topic created in 1622 days ago, the information mentioned may be changed or developed.

    现在有个项目要用 Ent 做数据库操作,但是有些表做了分表,Ent 如何处理呢?总不会是每个分表 都创建一个 Schema 吧?如何能做到一个表 Schema 根据一定规则获取不同分表的数据呢?求教求教。

    10 replies    2021-11-22 21:08:52 +08:00
    matrix1010
        1
    matrix1010  
       Nov 19, 2021
    请看这个 PR 里我的回答: https://github.com/ent/ent/pull/2020 。需要你动动手加 template ,但是如果熟悉 Ent 应该不难
    antxiaoye
        2
    antxiaoye  
    OP
       Nov 20, 2021
    @matrix1010 刚用 Ent , template 还没弄明白呢 T_T~
    matrix1010
        3
    matrix1010  
       Nov 20, 2021
    @antxiaoye 只有增加需要 template ,删改查用 s.From(table)就行
    antxiaoye
        4
    antxiaoye  
    OP
       Nov 20, 2021
    @matrix1010 有相关文档吗?哥,小弟听不懂啊~~,我也出现了“query error Error 1146: Table 'test.apple' doesn't exist”,这种问题,和你的 GitHub 里的回答一样,不知道怎么处理好。
    matrix1010
        5
    matrix1010  
       Nov 20, 2021
    client.User.Query().Where(
    func(s *sql.Selector) {
    table := sql.Table("user_table_1")
    s.From(table)
    },
    ).All(context.TODO()) 我觉得这个挺明确啊,user_table_1 是你的分表
    antxiaoye
        6
    antxiaoye  
    OP
       Nov 20, 2021
    @matrix1010 这里我确实是这么做的,但是结果却报没有字段错误,例如:“ Error 1054: Unknown column 'user.id' in 'field list' FAIL”!

    是不是 Schema 那边我使用了 Mixin 导致的?我创建了 usermixin.go 做公共 Schema ,然后为每个分表创建一个 Schema 在复用 usermixin.go 定义的字段和索引。

    老哥能否指点一下 template 是怎么实现的吗?官方文档我看得有点懵了~~
    matrix1010
        7
    matrix1010  
       Nov 20, 2021
    @antxiaoye template 要靠你自己去理解了,因为比较复杂我几句话也没法解释到让你明白。首先你要对 go 的代码生成有个概念 https://pkg.go.dev/text/template ,比如变量怎么定义,怎么引用其他的 template 。然后你要学习 Ent 的代码生成方式,比如 create 对应的就是这个: https://github.com/ent/ent/blob/master/entc/gen/template/dialect/sql/create.tmpl
    antxiaoye
        8
    antxiaoye  
    OP
       Nov 22, 2021
    @matrix1010 感谢大佬指点,我尝试和好几个办法,都不好使,最后我直接改 meta.tmpl 模板了,将常量 Table 改成变量,查询的时候直接改 Table 的值,不晓得这么做有没有副作用~~
    matrix1010
        9
    matrix1010  
       Nov 22, 2021
    @antxiaoye 你能用就行。不过要是经常要分表建议你考虑考虑要不迁移到 tidb/polardb 上。或者直接 nosql
    antxiaoye
        10
    antxiaoye  
    OP
       Nov 22, 2021 via Android
    @matrix1010 是有计划用 polardb ~
    About     Help     Advertise     Blog     API     FAQ     Solana     1061 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 33ms UTC 22:48 PVG 06:48 LAX 15:48 JFK 18:48
    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