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

2016-06-08 16:55:53 +08:00
 Liang
一张表存了[省]、[市]、[区]的数据,以 parent_id 来指定父级,[省]的 parent_id 自然等于 0 了。

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

目前只想到循环累加(捂脸。。。
2842 次点击
所在节点    程序员
12 条回复
murmur
2016-06-08 17:02:01 +08:00
不要考虑那么多 省市区数据很多网站都是当 json 一堆全返回到前台来 这点数据量想怎么做就怎么做
annielong
2016-06-08 17:04:25 +08:00
join 或者 select 都可以啊,又不是前台,你这是数据库
Wicheol
2016-06-08 17:08:54 +08:00
表是不是太复杂了?地区编号是 aabbcc , aa 是省编码, bb 是市编码, cc 是区编码
找省内多少个区,一个 count 就出来了啊
187j3x1
2016-06-08 17:11:59 +08:00
能有几个区?这点数据量几个循环能慢到哪啊
Wicheol
2016-06-08 17:13:05 +08:00
如果只是做省市区联动完全可以用统计局的数据,导到数据库就能用
http://www.stats.gov.cn/tjsj/tjbz/xzqhdm/201504/t20150415_712722.html
lujjjh
2016-06-08 18:09:23 +08:00
子查询或者 JOIN 都是可行的方案。

https://gist.github.com/anonymous/189290891ba8d09616e96d1855b90ef0
junzki
2016-06-08 20:55:02 +08:00
我在设计库的时候把行政区划码每两位一组拆开了,然后一个 select 搞定。
junzki
2016-06-08 20:55:47 +08:00
@Wicheol 统计局的行政区划码非常好用。
imNull
2016-06-08 21:32:57 +08:00
1 楼正解
Lpl
2016-06-08 22:00:09 +08:00
https://github.com/penglongli/a-simple-citySeleter ,一个省市区联动的东西,在别人基础上改的,在 demo 文件夹中,数据还是比较全的。
realpg
2016-06-08 23:01:57 +08:00
告诉我不是只有我觉得这么设计数据库结构很 2
Kokororin
2016-06-09 07:48:22 +08:00
淘宝全把 json 数据写在 js 里

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/284423

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX