Day96 Java项目 (SSM+Dubbo)商城(五) 统计分析

1.商品类目销售分析表

一.需求分析

  1. 商品类目销售分析是统计一段时间内各商品分类(一级分类)的销售数量与销售额以及所占总额的比重,如下图:

二.实现思路

  1. 销售分析表数据来自订单表和订单明细表,我们需要对订单表和订单明细表进行统计。订单明细表中记录了商品的一级分类,我们按照一级分类聚合运算就可以统计出各分类的销售额。
  2. 销售金额的统计要按照优惠后的金额(pay_money)进行统计。
  3. 订单表和订单明细表数据量庞大,如果每次都对订单表和订单明细表实时统计,查询效率必然低下。所以我们对大数量的表进行统计,通常是每天定时统计上一天的数据,将统计结果存储在一张表中。当用户执行管理后台的统计功能时,再对这张表进行统计,给前端返回统计结果。
  4. 表结构 :

三.类目统计SQL语句

  1. 按照商品一级分类、二级分类、三级分类聚合统计销售数量和销售金额,查询条件为支付状态为已支付,未删除的数据并且支付日期为某日的。
  2.  

四.类目统计代码实现

  1. 创建实体类
  2. 新建数据访问接口CategoryReportMapper
  3. 新建业务接口CategoryReportService
  4. 新建业务实现
  5. 新建Controller

五.定时任务-生成统计数据

创建定时任务,每天凌晨1点统计昨天的数据,插入到tb_category_report中。

  1. CategoryReportService新增方法定义
  2. CategoryReportServiceImpl实现方法

    CategoryReportServiceImpl的service注解添加属性
  3. OrderTask新增方法

六.按日期统计一级分类数据

  1. 我们再次对tb_category_report进行聚合运算,得出一个时间段的统计数据
  2. 在CategoryReportMapper新增方法
  3. CategoryReportService新增方法
  4. CategoryReportServiceImpl实现方法
  5. CategoryReportController新增方法

七.商品类目统计名称显示

  1. 创建视图
    分类名称所在的分类表在商品数据库中,而当前我们连接的是订单数据库,这种情况下我们需要在订单数据库中创建视图,让其得到一级分类列表。
  2. 改造之前的sql语句
  3. 修改CategoryReportMapper接口category1Count方法的sql语句

八.商品类目统计前端实现

  1. 创建report/categoryReport.html页面,引入样式和js

  2. 创建表格
  3. 创建日期范围控件
  4. 编写脚本

2.EChars图表插件

一.EChars简介

  1. ECharts,百度开源的图表插件。一个使用 JavaScript 实现的开源可视化库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等),底层依赖轻量级的矢量图形库 ZRender,提供直观,交互丰富,可高度个性化定制的数据可视化图表。
  2. 详见EChars官网 https://echarts.baidu.com/

二.简单柱状图

  1. 新建页面,引入js
  2. 在页面放置 div用于显示报表
  3. 编写js代码
  4. 图例

三.多数据的柱状图

四.简单饼图

五.多数据的饼图

3.商品类目销售统计(饼图)

一.需求分析

  1. 根据商品类目销售分析表生成饼图,如下图。左侧的饼图为销售量统计分析图,右侧的饼图为销售额统计分析图。

二.实现思路

  1. EChars有自己的数据格式,我们可以将后端返回的商品类目销售分析表的数据进行整理,得到EChars需要的数据格式。
  2. 使用EChars的饼图控件。

三.代码实现

  1. 页面引入js
  2. 在页面放置 div用于显示报表
  3. 修改fetchData方法,在回调处添加代码

4.流量统计

一.相关术语

  1. IP :
            IP(独立IP),即Internet Protocol,这里是指独立IP数,独立IP是指不同IP地址的计算机访问网站时被计的总次数。独立IP数是衡量网站流量的一个重要指标。一般一天内(00:00-24:00)相同IP地址的客户端访问网站页面只会被计为一次. 假设公司很多人在局域网中同时打开网站,此时只能算一个独立IP。
  2. UV :
            UV(独立访客)即Unique Visitor,同一个客户端(PC或移动端)访问网站被计为一个访客。一天(00:00-24:00)内相同的客户端访问同一个网站只计一次UV。UV一般是以客户端Cookie等技术作为统计依据的,实际统计会有误差。
  3. PV :
            PV(访问量)即Page View ,中文翻译为页面浏览,即页面浏览量或点击量,不管客户端是不是不同,也 不管IP是不是不同,用户只要访问网站页面就会被计算PV,一次计一个PV。

二.百度统计

  1. 全球最大的中文网站流量分析平台,帮助企业收集网站访问数据,提供流量趋势、来源分析、转化跟踪、页面热力图、访问流等多种统计分析服务,同时与百度搜索、百度推广、云服务无缝结合,为网站的精细化运营决策提供数据支持,进而有效提高企业的投资回报率。
  2. https://tongji.baidu.com/

5.交易统计

一.交易统计表

  1. 需求分析 :
    实现交易数据统计,以表格形式展现浏览人数 下单人数 订单数 下单件数 有效订单数 下单金额 退款金额 付款人数 付款订单数 付款件数 付款金额
  2. 实现思路 :
    (1)创建交易统计表,用于存储每天的统计结果(表结构学员定义)
    (2)编写代码,创建定时任务,在凌晨1点执行统计,将统计结果插入到交易统计表
    (3)编写代码,实现对交易统计表的聚合运算(按时间段查询)
    (4)浏览人数可以通过调用“百度统计”API获取。
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值