aibuzhe
V2EX  ›  Django

django 水平分表,如何将多个表的数据进行汇总分页?

  •  
  •   aibuzhe · Dec 2, 2019 · 4676 views
    This topic created in 2361 days ago, the information mentioned may be changed or developed.
    另外,水平分表后,filter 要从多张表查询,不仅增加了查询次数,还要对结果进行合并。性能上是否可取?
    12 replies    2020-04-09 16:15:24 +08:00
    aibuzhe
        1
    aibuzhe  
    OP
       Dec 2, 2019
    有经历过的吗?
    aibuzhe
        2
    aibuzhe  
    OP
       Dec 2, 2019
    有了两条回复后,主题是否可以修改
    aibuzhe
        3
    aibuzhe  
    OP
       Dec 2, 2019
    实测 V2EX,不论是问题还是主题,只要有了 2 条回复,变不可修改
    NaVient
        4
    NaVient  
       Dec 2, 2019   ❤️ 1
    数据库层面做分表逻辑,不牵扯业务层
    zhoudaiyu
        5
    zhoudaiyu  
    PRO
       Dec 2, 2019 via iPhone
    OneToOneField ?
    wuwukai007
        6
    wuwukai007  
       Dec 2, 2019 via Android
    写原生 sql 吧
    wzwwzw
        7
    wzwwzw  
       Dec 2, 2019
    写原生 sql 吧。
    dusu
        8
    dusu  
       Dec 2, 2019 via iPhone
    有个东西叫索引表
    Jemini
        9
    Jemini  
       Dec 2, 2019 via iPhone
    union all 可以联表
    SmiteChow
        10
    SmiteChow  
       Dec 4, 2019
    水平分表实质上是把需要查询的字段归集到一张表 A,其他额外信息字段归集到额外表 B.C..X,业务请求时查询 A 表拿到所有主键,再根据主键拉去 B.C..X 表中额外信息,通常分页情况下主键数量是可控的,性能没问题。
    SmiteChow
        11
    SmiteChow  
       Dec 4, 2019
    性能当然没问题,分表不就是为了解决性能问题吗?差点被你绕进去
    aibuzhe
        12
    aibuzhe  
    OP
       Apr 9, 2020
    @SmiteChow 你这个是垂直分表吧
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1446 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 65ms · UTC 17:03 · PVG 01:03 · LAX 10:03 · JFK 13:03
    ♥ Do have faith in what you're doing.