V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
Liang
V2EX  ›  程序员

数据库三级联动怎么统计的效率最高?

  •  
  •   Liang · Jun 8, 2016 · 3274 views
    This topic created in 3616 days ago, the information mentioned may be changed or developed.
    一张表存了[省]、[市]、[区]的数据,以 parent_id 来指定父级,[省]的 parent_id 自然等于 0 了。

    统计[市]的数量很简单,直接 count: parent_id=ID 就 OK 。现在要统计[广东省]有多少个区,怎样的语句得出的结果效率最高?

    目前只想到循环累加(捂脸。。。
    12 replies    2016-06-09 07:48:22 +08:00
    murmur
        1
    murmur  
       Jun 8, 2016
    不要考虑那么多 省市区数据很多网站都是当 json 一堆全返回到前台来 这点数据量想怎么做就怎么做
    annielong
        2
    annielong  
       Jun 8, 2016
    join 或者 select 都可以啊,又不是前台,你这是数据库
    Wicheol
        3
    Wicheol  
       Jun 8, 2016
    表是不是太复杂了?地区编号是 aabbcc , aa 是省编码, bb 是市编码, cc 是区编码
    找省内多少个区,一个 count 就出来了啊
    187j3x1
        4
    187j3x1  
       Jun 8, 2016   ❤️ 1
    能有几个区?这点数据量几个循环能慢到哪啊
    Wicheol
        5
    Wicheol  
       Jun 8, 2016   ❤️ 1
    如果只是做省市区联动完全可以用统计局的数据,导到数据库就能用
    http://www.stats.gov.cn/tjsj/tjbz/xzqhdm/201504/t20150415_712722.html
    lujjjh
        6
    lujjjh  
       Jun 8, 2016
    子查询或者 JOIN 都是可行的方案。

    https://gist.github.com/anonymous/189290891ba8d09616e96d1855b90ef0
    junzki
        7
    junzki  
       Jun 8, 2016
    我在设计库的时候把行政区划码每两位一组拆开了,然后一个 select 搞定。
    junzki
        8
    junzki  
       Jun 8, 2016
    @Wicheol 统计局的行政区划码非常好用。
    imNull
        9
    imNull  
       Jun 8, 2016 via Android
    1 楼正解
    Lpl
        10
    Lpl  
       Jun 8, 2016 via Android
    https://github.com/penglongli/a-simple-citySeleter ,一个省市区联动的东西,在别人基础上改的,在 demo 文件夹中,数据还是比较全的。
    realpg
        11
    realpg  
    PRO
       Jun 8, 2016
    告诉我不是只有我觉得这么设计数据库结构很 2
    Kokororin
        12
    Kokororin  
       Jun 9, 2016 via iPhone
    淘宝全把 json 数据写在 js 里
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2587 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 45ms · UTC 12:39 · PVG 20:39 · LAX 05:39 · JFK 08:39
    ♥ Do have faith in what you're doing.