日期:2014-05-16  浏览次数:20641 次

用于统计移动端用户信息的数据库设计
我们公司是做手机app的,现在要统计用户的信息。已有条件:每个用户唯一ID,其属性有产品名,版本名,系统名,安装日期,国家,运营商等等。现在要按照时间的维度(日、周、月)统计每个属性下的用户量,还要支持组合式统计(比如统计2012年3月2日使用Android4.1系统的日本用户有多少)。难点在于,对于一个ID下的每个属性,都是有可能变的。比如,2月1日某用户使用的是Android4.0,但他7号刷系统刷到了4.1,那这个人在1号到7号的周统计中就只能算作4.1的用户。 我现在想到的是按天存每个用户的详细信息,每天、每周、每月都存一个总结表。但对于组合式搜索还是比较慢,望各位大神畅所欲言,给小弟一些数据库设计方面的经验。

------解决方案--------------------
LaunchUser :
SummaryDate ID 属性ID 属性种类ID

属性对照表:
属性ID 属性名称
2 Device
1 Location

属性种类对照表:
属性ID 属性种类ID 属性名称
1 1 ....
1 2 ....
------解决方案--------------------
这些字段 System Device Location Language