日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

瀏覽:101日期:2023-03-05 11:34:04
一、提出任務(wù)

查詢班級(jí)表數(shù)據(jù),利用ECharts繪制各班人數(shù)柱形圖。

(一)班級(jí)數(shù)據(jù)

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

(二)運(yùn)行效果

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

二、實(shí)現(xiàn)步驟

(一)創(chuàng)建數(shù)據(jù)庫(kù)與表

1、創(chuàng)建數(shù)據(jù)庫(kù) - test

create database test;

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

2、創(chuàng)建數(shù)據(jù)表 - t_class 創(chuàng)建表結(jié)構(gòu)

CREATE TABLE `t_class` ( `id` int(11) NOT NULL AUTO_INCREMENT, `class` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL, `boys` int(11) DEFAULT NULL, `girls` int(11) DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

插入表記錄

INSERT INTO `t_class` VALUES (1, ’19軟件1班’, 26, 18);INSERT INTO `t_class` VALUES (2, ’19軟件2班’, 17, 20);INSERT INTO `t_class` VALUES (3, ’19大數(shù)據(jù)1班’, 24, 30);INSERT INTO `t_class` VALUES (4, ’19計(jì)應(yīng)1班’, 21, 24);

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

查看表記錄

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

(二)創(chuàng)建Spring Boot項(xiàng)目 - EChartsDemo

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

(三)創(chuàng)建班級(jí)實(shí)體類 - Clazz

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

package net.hw.echarts.bean;/** * 功能:班級(jí)實(shí)體類 * 作者:華衛(wèi) * 日期:2021年06月04日 */public class Clazz { private int id; private String clazz; private int boys; private int girls; public int getId() {return id; } public void setId(int id) {this.id = id; } public String getClazz() {return clazz; } public void setClazz(String clazz) {this.clazz = clazz; } public int getBoys() {return boys; } public void setBoys(int boys) {this.boys = boys; } public int getGirls() {return girls; } public void setGirls(int girls) {this.girls = girls; } @Override public String toString() {return 'Clazz{' +'id=' + id +', clazz=’' + clazz + ’’’ +', boys=' + boys +', girls=' + girls +’}’; }}

(四)創(chuàng)建班級(jí)映射器接口 - ClazzMapper

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

package net.hw.echarts.mapper;import net.hw.echarts.bean.Clazz;import org.apache.ibatis.annotations.Mapper;import java.util.List;/** * 功能:班級(jí)映射器接口 * 作者:華衛(wèi) * 日期:2021年06月04日 */@Mapperpublic interface ClazzMapper { List<Clazz> findAll();}

(五)創(chuàng)建班級(jí)映射器配置文件 - ClazzMapper.xml

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapperPUBLIC '-//mybatis.org//DTD Mapper 3.0//EN''http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='net.hw.echarts.mapper.ClazzMapper'> <!--定義結(jié)果映射,因?yàn)楸碜侄蚊c實(shí)體屬性名不完全一致--> <resultMap type='net.hw.echarts.bean.Clazz'><result property='id' column='id'/><result property='clazz' column='class'/><result property='boys' column='boys'/><result property='girls' column='girls'/> </resultMap> <select resultMap='clazzMap'>SELECT * FROM t_class; </select></mapper>

(六)創(chuàng)建班級(jí)服務(wù)類 - ClazzService

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

package net.hw.echarts.service;import net.hw.echarts.bean.Clazz;import net.hw.echarts.mapper.ClazzMapper;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;/** * 功能:班級(jí)服務(wù)類 * 作者:華衛(wèi) * 日期:2021年06月04日 */@Servicepublic class ClazzService { @Autowired(required = false) private ClazzMapper clazzMapper; public List<Clazz> findAll() {return clazzMapper.findAll(); }}

(七)創(chuàng)建班級(jí)控制器 - ClazzController

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

package net.hw.echarts.controller;import net.hw.echarts.bean.Clazz;import net.hw.echarts.service.ClazzService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;import java.util.List;/** * 功能:班級(jí)控制器 * 作者:華衛(wèi) * 日期:2021年06月04日 */@Controllerpublic class ClazzController { @Autowired private ClazzService clazzService; @GetMapping('/index') public String index() {return 'index'; } @RequestMapping(value = '/getAll', produces = 'application/json; charset=utf-8') @ResponseBody public List<Clazz> getAll() {List<Clazz> clazzes = clazzService.findAll();return clazzes; }}

(八)在項(xiàng)目里添加ECharts和jQuery 在static里創(chuàng)建js目錄,添加echarts.min.js與jquery.min.js

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

(九)在pom.xml文件里添加Druid依賴

<dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.6</version></dependency>

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

(十)配置數(shù)據(jù)源與MyBatis 將application.properties更名為application.yaml

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/test?serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8 username: root password: root type: com.alibaba.druid.pool.DruidDataSource druid: initial-size: 20 max-active: 100 min-idle: 10mybatis: mapper-locations: classpath:mapper/*.xml type-aliases-package: net.hw.echarts.bean

(十一)創(chuàng)建顯示可視化數(shù)據(jù)的頁(yè)面 - index.html

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>19級(jí)各班人數(shù)柱狀圖</title> <script src='http://m.b3g6.com/bcjs/js/jquery.min.js'></script> <script src='http://m.b3g6.com/bcjs/js/echarts.min.js'></script> <style>.box { width: 600px; height: 400px; border: 1px solid cornflowerblue;} </style></head><body><input type='button' value='顯示柱狀圖' /><hr/><div class='box'></div><script> // 獲取box元素 var box = document.getElementsByClassName('box')[0]; // 獲取btnShowBar元素 var btnShowBar = document.getElementsByClassName('btnShowBar')[0]; // 定義按鈕單擊事件 btnShowBar.onclick = function () {// 獲取后臺(tái)返回的JSON數(shù)據(jù)$.get(’/getAll’, function (data) { // 定義三個(gè)數(shù)組 class_list = []; boy_list = []; girl_list = []; // 將json數(shù)據(jù)寫入數(shù)組 for (var i = 0; i < data.length; i++) {class_list.push(data[i].clazz);boy_list.push(data[i].boys);girl_list.push(data[i].girls); } // 1. 初始化ECharts var my_box = echarts.init(box); // 2. 進(jìn)行參數(shù)配置 var option = {// 標(biāo)題title: { text: '19級(jí)各班人數(shù)條形圖', x: 'center', y: 'top', textAlign: 'left', textStyle: {fontFamily: '楷體',fontSize: 35,textStyle: 'bold' }},// 圖例legend: { left: 'right', orient: 'vertical'},// x軸數(shù)據(jù)xAxis: { data: class_list},// y軸數(shù)據(jù)yAxis: {},// 數(shù)據(jù)信息series: [ {name: '男生人數(shù)',type: 'bar',data: boy_list,itemStyle: { normal: {color: ’#0000aa’ }} }, {name: '女生人數(shù)',type: 'bar',data: girl_list,itemStyle: { normal: {color: ’#aa0000’ }} }] } // 3. 可視化呈現(xiàn) my_box.setOption(option);}); }</script></body></html>

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

(十二)啟動(dòng)應(yīng)用,查看結(jié)果 啟動(dòng)應(yīng)用

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

訪問(wèn)http://localhost:8080/index

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

單擊【顯示柱狀圖】按鈕

SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的

到此這篇關(guān)于SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的的文章就介紹到這了,更多相關(guān)SpringBoot可視化數(shù)據(jù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩亚洲一区在线观看| 136国产福利精品导航网址| 亚洲精品极品少妇16p| 激情视频一区二区三区| 久久精品一区二区不卡| 久久蜜桃资源一区二区老牛| 欧美特黄a级高清免费大片a级| 一本一道久久a久久精品蜜桃| 91成人精品视频| 1024精品久久久久久久久| 久久国产福利| 国产精品tv| 久久亚洲专区| 亚洲精品自拍| 麻豆视频久久| 亚洲精品小说| 国产亚洲观看| 日韩视频网站在线观看| 国产免费成人| 91成人精品在线| 国产在线|日韩| 91av一区| 欧美日韩视频| 久久午夜影院| 自由日本语亚洲人高潮| 欧美亚洲三级| 免费观看不卡av| 国产精品一区二区三区美女| 欧美91精品| 精品中文字幕一区二区三区 | 久久久久久久久99精品大| 亚洲综合小说| 91免费精品| 欧美日韩亚洲三区| 91精品高清| 国产精品高颜值在线观看| 亚洲免费一区三区| 国产va在线视频| 国产亚洲第一伦理第一区| 午夜久久影院| 亚洲精品一区三区三区在线观看| 国产精品chinese| 久久激情五月激情| 婷婷亚洲精品| 免费人成黄页网站在线一区二区 | 国产精品地址| 国产精品手机在线播放| 亚洲精品裸体| 午夜在线视频一区二区区别| 亚洲精品一区三区三区在线观看| 久久狠狠久久| 清纯唯美亚洲综合一区| 日本成人在线视频网站| 蜜桃久久久久久久| 日韩中文欧美在线| 免费精品视频最新在线| 亚洲黄色影院| 免费精品视频最新在线| 麻豆成人在线| 亚洲精品成a人ⅴ香蕉片| 视频一区在线视频| 久久99伊人| 亚洲综合福利| 天堂va欧美ⅴa亚洲va一国产| 另类激情亚洲| 日本成人在线视频网站| 综合国产精品| 欧美偷窥清纯综合图区| 美女尤物国产一区| 老牛影视精品| 亚洲在线电影| 青草av.久久免费一区| 精品三级av在线导航| 国产在线|日韩| av成人国产| 国产香蕉精品| 97精品国产| 免费观看在线色综合| 亚洲2区在线| 国产美女视频一区二区| 色一区二区三区四区| 激情不卡一区二区三区视频在线| 日本高清不卡一区二区三区视频 | 日韩成人一级| 天堂中文av在线资源库| 午夜在线播放视频欧美| 国产精品theporn| 欧美日韩国产高清电影| 日韩精品午夜视频| 日韩一区二区三区免费播放| 久久亚洲视频| 超碰成人av| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美一级二级视频| 欧美日韩国产免费观看| 国产精品porn| 亚洲九九精品| 亚洲一级二级| 精品国产99| 国产欧美高清视频在线| 男人天堂欧美日韩| 色88888久久久久久影院| 国产亚洲高清在线观看| 亚洲一区二区三区高清| 日韩啪啪电影网| 精品亚洲成人| 日韩不卡一区二区| 国产精品普通话对白| 日本精品国产| 日韩视频一区| 久久香蕉国产| 中国字幕a在线看韩国电影| 91精品丝袜国产高跟在线| 丝袜美腿一区二区三区| 亚洲婷婷在线| 九九色在线视频| 91视频久久| 国产精品毛片一区二区在线看| 国产精品伊人| 欧美三级第一页| 久久国产三级| 欧美日韩国产一区二区在线观看| 亚洲精品在线二区| 999在线观看精品免费不卡网站| 欧美13videosex性极品| 日韩理论片av| 桃色一区二区| 国产精品av久久久久久麻豆网| 99久久精品国产亚洲精品| 91青青国产在线观看精品| 高清久久精品| 中文字幕系列一区| 日韩亚洲在线| 视频一区中文字幕国产| 日韩欧美中文字幕电影| 欧美日韩亚洲一区三区| 美女视频黄 久久| caoporn视频在线| 日韩在线观看不卡| 免费精品国产| 综合激情婷婷| 国产精品成人自拍| 狂野欧美性猛交xxxx| 91日韩免费| 日韩一级精品| 欧美激情精品| 波多野结衣一区| 日本一区二区三区中文字幕| 国产精品nxnn| 一区在线免费观看| 日本a级不卡| 另类中文字幕国产精品| 亚洲三级av| 精品国产网站| 在线亚洲观看| 精品久久福利| 男女性色大片免费观看一区二区| 国产精品成人3p一区二区三区| 欧美不卡视频| 欧美综合社区国产| 国产视频久久| 日本久久黄色| 国产精品日韩精品在线播放| 激情欧美国产欧美| 青青草91视频| 在线亚洲国产精品网站| 精品亚洲精品| 久久国产乱子精品免费女| 日韩精品午夜| 国产伦精品一区二区三区千人斩 | 夜夜嗨一区二区三区| 国产成年精品| 国产欧美久久一区二区三区| 亚洲美洲欧洲综合国产一区| 国产成人精品一区二区三区视频| 亚洲精品大全| 视频一区二区中文字幕| 久久人人97超碰国产公开结果| 国产精品美女午夜爽爽| 亚洲丝袜美腿一区| 日本在线精品| 中文字幕系列一区| 91亚洲自偷观看高清| 国产精品探花在线观看| 日本色综合中文字幕| 蜜桃久久av一区| 亚洲作爱视频| 夜久久久久久| 亚洲激情精品| 亚洲一区中文| 影音国产精品| 免费日韩精品中文字幕视频在线| 五月天久久777| 性色一区二区| 天堂俺去俺来也www久久婷婷| 美女久久网站| 亚洲欧美网站在线观看| 一区二区电影在线观看| 三级亚洲高清视频| 婷婷五月色综合香五月|