Echarts整合(前后端、数据库)

Echarts整合(前后端、数据库)

官方网站:https://echarts.apache.org/examples/zh/index.html

一、前端

0.安装echarts

npm install echarts –save

1.编写html

用来显示图表

<div class="chart-container">
  <div id="chart" class="chart" style="height:500px;width:100%" />
</div>

触发显示图标的按钮

<el-button
  :disabled="btnDisabled"
  type="primary"
  icon="el-icon-search"
  @click="showChart()">查询</el-button>

2.引入echart

四版本

import echarts from 'echarts'

五版本

import * as echarts from 'echarts'

3.编写调用方法

编写方法getDataSta(),用来获取后端数据

<span>Echarts整合(前后端、数据库)</span>

//用来获取后端数据
  getDataSta(searchObj) {
    return request({
      url: `/staservice/sta/showData/${searchObj.type}/${searchObj.begin}/${searchObj.end}`,
      method: 'get'
    })
  }

4.编写js

showChart():用来获取后端传来的数据

其中格式必须为json数组格式

setChart()固定写法

一般只修改x,y轴数据就可以

methods:{
  showChart() {
    staApi.getDataSta(this.searchObj)
      .then(response => {
        console.log('*****************'+response)
        this.yData = response.data.numDataList
        this.xData = response.data.date_calculatedList

        //调用下面生成图表的方法,改变值
        this.setChart()
      })
  },
  setChart() {
    // 基于准备好的dom,初始化echarts实例
    this.chart = echarts.init(document.getElementById('chart'))
    // console.log(this.chart)

    // 指定图表的配置项和数据
    var option = {
      title: {
        text: '数据统计'
      },
      tooltip: {
        trigger: 'axis'
      },
      dataZoom: [{
        show: true,
        height: 30,
        xAxisIndex: [
          0
        ],
        bottom: 30,
        start: 10,
        end: 80,
        handleIcon: 'path://M306.1,413c0,2.2-1.8,4-4,4h-59.8c-2.2,0-4-1.8-4-4V200.8c0-2.2,1.8-4,4-4h59.8c2.2,0,4,1.8,4,4V413z',
        handleSize: '110%',
        handleStyle: {
          color: '#d3dee5'

        },
        textStyle: {
          color: '#fff'
        },
        borderColor: '#90979c'
      },
        {
          type: 'inside',
          show: true,
          height: 15,
          start: 1,
          end: 35
        }],
      // x轴是类目轴(离散数据),必须通过data设置类目数据
      xAxis: {
        type: 'category',
        data: this.xData
      },
      // y轴是数据轴(连续数据)
      yAxis: {
        type: 'value'
      },
      // 系列列表。每个系列通过 type 决定自己的图表类型
      series: [{
        // 系列中的数据内容数组
        data: this.yData,
        // 折线图
        type: 'line'
      }]
    }

    this.chart.setOption(option)
  }
}

二、后端

1.控制层接受前端数据

/**
 * 图表显示,返回日期和数量数组
 * @param begin 开始日期
 * @param end 结束日期
 * @param type 查询类型
 * @return
 */
@ApiOperation("图表显示,返回日期和数量数组")
@GetMapping("showData/{type}/{begin}/{end}")
public Result showData(@PathVariable String type,
                       @PathVariable String begin,
                       @PathVariable String end){
    Map<String,Object> map = statisticsDailyService.getData(type,begin,end);
    return Result.ok().data(map);
}

2.实现类的方法

获取数据库中的数据,

将结果封装在两个list中

​ 日期list
​ 数量list

/**
 * 获取统计数据
 * @param type 查询类型(注册、播放数量等)
 * @param begin 开始时间
 * @param end 结束时间
 * @return map
 */
@Override
public Map<String, Object> getData(String type, String begin, String end) {
    QueryWrapper<StatisticsDaily> queryWrapper = new QueryWrapper<>();
    //筛选日期
    queryWrapper.between("date_calculated",begin,end);
    //精准查询日期和选择的类型
    queryWrapper.select("date_calculated",type);
    List<StatisticsDaily> statisticsDailies = baseMapper.selectList(queryWrapper);
    //将结果封装在两个list中
    //日期list
    List<String> dateCalculatedList = new ArrayList<>();
    //数量list
    List<Integer> countList = new ArrayList<>();
    for (StatisticsDaily daily : statisticsDailies) {
        dateCalculatedList.add(daily.getDateCalculated());
        switch (type) {
            case "login_num":
                countList.add(daily.getLoginNum());
                break;
            case "register_num":
                countList.add(daily.getRegisterNum());
                break;
            case "video_view_num":
                countList.add(daily.getVideoViewNum());
                break;
            case "course_num":
                countList.add(daily.getCourseNum());
                break;
            default:
                break;
        }
    }
    HashMap<String, Object> map = new HashMap<>();
    map.put("date_calculatedList",dateCalculatedList);
    map.put("numDataList",countList);
    return map;
}

三、数据库

<span>Echarts整合(前后端、数据库)</span>

1.建表语句

CREATE TABLE `statistics_daily` (  `id` char(19) NOT NULL COMMENT '主键',  `date_calculated` varchar(20) NOT NULL COMMENT '统计日期',  `register_num` int(11) NOT NULL DEFAULT '0' COMMENT '注册人数',  `login_num` int(11) NOT NULL DEFAULT '0' COMMENT '登录人数',  `video_view_num` int(11) NOT NULL DEFAULT '0' COMMENT '每日播放视频数',  `course_num` int(11) NOT NULL DEFAULT '0' COMMENT '每日新增课程数',  `gmt_create` datetime NOT NULL COMMENT '创建时间',  `gmt_modified` datetime NOT NULL COMMENT '更新时间',  PRIMARY KEY (`id`),  KEY `statistics_day` (`date_calculated`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='网站统计日数据';

2.记录来源

方法一:在控制层有可以主动调用的接口来查询注册人数等数据信息

方法二:在定时任务中可以每天定时调用service的方法来统计

<span>Echarts整合(前后端、数据库)</span>

定时任务

@Componentpublic class ScheduleTask {    @Autowired    private StatisticsDailyService statisticsDailyService;    /**     * 定时任务     * 每天凌晨1点自动查询前一天的统计数据     */    @Scheduled(cron = "0 0 1 * * ?")    public void updateStatisticsInfo() {        //计算前一天日期        String preDay = DateUtil.formatDate(DateUtil.addDays(new Date(),-1));        statisticsDailyService.countRegister(preDay);    }}

统计方法

/**
 * 统计人数
 * @param day 日期
 */
@Transactional(rollbackFor = Exception.class)
@Override
public void countRegister(String day) {
    //防止重复添加,先删除
    baseMapper.delete(new QueryWrapper<StatisticsDaily>().eq("date_calculated",day));
    Result result = ucenterClient.countRegister(day);
    int countRegister = (int)result.getData().get("countRegister");
    StatisticsDaily statisticsDaily = new StatisticsDaily();
    //赋值统计的数据
    statisticsDaily.setRegisterNum(countRegister);
    statisticsDaily.setDateCalculated(day);
    // TODO 随机数改为真实数据
    statisticsDaily.setVideoViewNum( RandomUtils.nextInt(100,200));
    statisticsDaily.setLoginNum(RandomUtils.nextInt(100,200));
    statisticsDaily.setCourseNum(RandomUtils.nextInt(100,200));
    //添加到数据库中
    baseMapper.insert(statisticsDaily);
}

四、实体数据

@TableField(fill = FieldFill.INSERT_UPDATE)注解 需要配置类

package com.gyb.staservice.entity;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;

import java.io.Serializable;
import java.util.Date;

/**
 * <p>
 * 网站统计日数据
 * </p>
 *
 * @author 郜宇博
 * @since 2021-10-27
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value="StatisticsDaily对象", description="网站统计日数据")
public class StatisticsDaily implements Serializable {

    private static final long serialVersionUID=1L;

    @ApiModelProperty(value = "主键")
    @TableId(value = "id", type = IdType.ID_WORKER_STR)
    private String id;

    @ApiModelProperty(value = "统计日期")
    private String dateCalculated;

    @ApiModelProperty(value = "注册人数")
    private Integer registerNum;

    @ApiModelProperty(value = "登录人数")
    private Integer loginNum;

    @ApiModelProperty(value = "每日播放视频数")
    private Integer videoViewNum;

    @ApiModelProperty(value = "每日新增课程数")
    private Integer courseNum;

    @ApiModelProperty(value = "创建时间")
    @TableField(fill = FieldFill.INSERT)
    private Date gmtCreate;

    @ApiModelProperty(value = "更新时间")
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date gmtModified;


}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115162.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c++ 时间类型详解(time_t和tm)

    c++ 时间类型详解(time_t和tm)Unix时间戳(Unixtimestamp),或称Unix时间(Unixtime)、POSIX时间(POSIXtime),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒起至现在的总秒数。Unix时间戳不仅被使用在Unix系统、类Unix系统中,也在许多其他操作系统中被广告采用。目前相当一部分操作系统使用32位二进制数字表示时间。此类系统的Uni

    2025年5月23日
    3
  • C#开源资源大汇总

    C#开源资源大汇总

    2021年7月26日
    57
  • rj45 千兆接口定义_网线的RJ45接口的针脚定义「建议收藏」

    我们生活中常用的网线接头类型分为两类:用于连接到网络中的终端设备的DTE类型,如连接到PC机的网卡的网线属于DTE型。还有用于网络设备间连接的DCE类型,如路由器连接到交换机的线或交换机连接到交换机的线均属于DCE型。DTE我们称做“数据终端设备”,这里的终端是一个广义的概念,PC也可以是终端(一般广域网常用DTE设备有路由器、终端主机)。DCE我们称做“数据通信设备”,如MODEM,连接DTE设…

    2022年4月10日
    562
  • long型转String

    long型转Stringlonga1=12;Strings1=a1+””;//法1:直接加空串System.out.println(s1);longa2=34;Strings2=String.valueOf(a2);//法2:String.valueOf()System.out.pr…

    2022年5月15日
    37
  • 用Python做一个“以图搜番“的应用程序,再也不用愁动漫图片的出处了!

    用Python做一个“以图搜番“的应用程序,再也不用愁动漫图片的出处了!文章目录前言PyQt5界面设计使用QtDesigner绘制界面视频部件插入小技巧解码器下载功能实现trace.moeAPI介绍与视频使用Nuitka打包成exe文件前言喜欢看动漫的朋友们大概都能体会到一个难受的事情,就是在论坛或者群聊里面看到一张动漫截图,很想知道它的出处,但百度搜了一圈却也没有一个可靠结果,就很郁闷。今天就来带大家用Python做一个简单的“以图搜番”小应用。应用本身的实现不是很难的事情,其实就是调用别人的API接口来实现,主要目的还是通过这个案例来学习以下内容:学习如何用Py

    2022年10月9日
    3
  • 典型的电容有_电容的容量

    典型的电容有_电容的容量【硬见小百科】二十种电容分类详解!一、瓷介电容器(CC)【硬见小百科】二十种电容分类详解!1.结构用陶瓷材料作介质,在陶瓷表面涂覆一层金属(银)薄膜,再经高温烧结后作为电极而成。瓷介电容器又分1类电介质(NPO、CCG);2类电介质(X7R、2X1)和3类电介质(Y5V、2F4)瓷介电容器。2.特点1类瓷介电容器具有温度系数小、稳定性高、损耗低、耐压高等优点。最大容量不超过1…

    2022年8月22日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号