MySQL社区

标题: 求sql查询统计数据,实在想不出来,没辙了. [打印本页]

作者: jiangyang025    时间: 2007-11-6 15:46
提示: 作者被禁止或删除 内容自动屏蔽
作者: jeff    时间: 2007-11-6 16:20
这个问题确实对MySQL来说比较头疼,如果是其他数据库就方便多了,你可以先参考一下思路:
使用CUBE和ROLLUP对数据进行汇总
http://database.ctocio.com.cn/tips/88/7625588.shtml

而在MySQL中没有这种东西,就需要做更多的工作了。试试用编程和建一些中间表过度等...

在你的具体问题中,有些东西是重复统计,如拨入电话 、长途电话拨入量、长途电话总量,这种统计报表是不能通过单一SQL语句搞定的。建议你先分组统计(插入时间->通话类型->电话号码->长途短途等),形成视图或中间表/临时表,再进一步继续统计,填入数据...


希望能给你有所帮助。

[ 本帖最后由 jeff 于 2007-11-6 16:40 编辑 ]
作者: edwin_chen    时间: 2007-11-6 17:45
假设你的表叫 TEL

语句为:

SELECT tp1.日期, tp1.总通话量,  tp2.拨入电话, tp3.拨出电话
FROM
( SELECT DATE(t1.插入时间) as 日期, count(t1.id) as 总通话量 FROM TEL t1
  WHERE t1.插入时间 > '2007-11-01 00:00:00' AND t1.插入时间 < '2007-12-01 00:00:00'
GROUP BY DATE(t1.插入时间) ) tp1,
( SELECT DATE(t2.插入时间) as 日期, count(t2.id) as 拨入电话 FROM TEL t2
  WHERE t2.插入时间 > '2007-11-01 00:00:00' AND t2.插入时间 < '2007-12-01 00:00:00'  AND t2.通话类型 = '拨入'
GROUP BY DATE(t2.插入时间) ) tp2,
( SELECT DATE(t3.插入时间) as 日期, count(t3.id) as 拨出电话 FROM TEL t3
  WHERE t3.插入时间 > '2007-11-01 00:00:00' AND t3.插入时间 < '2007-12-01 00:00:00'  AND t3.通话类型 = '拨出'
GROUP BY DATE(t3.插入时间) ) tp3
WHERE tp1.日期 = tp2.日期 and tp1.日期 = tp3.日期 ;

这种写法效率是个问题,结果集如果很大的话,会很慢的。希望对你有帮助。

[ 本帖最后由 edwin_chen 于 2007-11-6 17:46 编辑 ]




欢迎光临 MySQL社区 (http://www.mysqlpub.com/) Powered by Discuz! X3.2