EasyExcel动态表头即动态数据生成

1️⃣ 业务需求

需要将数据库中的所有表放在一个下拉框中,下拉框支持模糊查询到相关的表,然后通过这个表名查询到数据库的数据,切换不同的表查询出来相关表的列和数据
需要注意的点: 1)js实现模糊搜索
           2)导出的表头和数据都是动态生成,切换a表就是导出a表的列和数据,切换b表就是b表的列和数据

2️⃣ 实现效果

选择一张表,查询出该表相关表头和数据

点击导出按钮,导出对应数据

选择另外一张表,查询出该表相关表头和数据

3️⃣ 查询实现

实现查询功能较为简单,就是后台查询表头列,然后js for循环实现列加入到table中

js部分

4️⃣ 导出实现(重点)

首先我用的框架即版本
  spring + mybatis + springmvc + easyexcel实现导出功能,除了easyexcel版本有需要注意,其他的自行版本对应;easyexcel的版本为:

  因为easyexcel对poi版本有版本对应,所以你的poi需要升级,poi版本为:

下图为官网版本对应:

接下来就是具体实现过程

这里需要注意的是,registerConverter方法,这个是一个自定义转换器,是用来转换mybatis的hashmap集合,转换的原因是:
  由于表格是动态的,他的数据以及表头都是根据你选择的表名来变化的,所以无法定义具体的实体类,所以mybatis那里我们只能写成Map而不是具体的entity

  easyexcel导出是不支持hashmap(mybatis,Map会自动转换为hashmap)的,会报一个转换错误的错,所以我们这里需要写转换器
转换器的具体实现:

最后最麻烦的就是数据结构:

最终通过不停的尝试,发现数据结构显示为上图,才会将数据导出来,但是又衍生出来了一个问题,数据导出来的,但是表名和数据匹配是乱的,所以还需要最后的一步就是将字段名和数据列对应
这里我的实现方法是直接循环hashmap,key为头,value为数据,然后各自进一步封装数据结构

5️⃣ 实现代码

接口实现类和mybatis xml的代码就不贴了,就是查询数据库sql,较简单
  // 表头
  List<List<String>> listHead = new ArrayList<>();

//导出功能 easyexcel 动态头导出
@RequestMapping(value = "/export", method = RequestMethod.GET)
public void export(HttpServletResponse response, HttpServletRequest request) throws UnsupportedEncodingException { try { response.setContentType("application/vnd.ms-excel;charset=utf-8"); response.setCharacterEncoding("UTF-8"); String fileName = URLEncoder.encode("test", "UTF-8"); response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx"); String tableName = request.getParameter("tableName"); EasyExcel.write(response.getOutputStream())
.registerConverter(new config())
.head(head1(tableName)).sheet("模板")
.doWrite(data(tableName
)); // 每次导出完清空listHead
listHead.clear(); } catch (Exception e) { e.printStackTrace(); } } private List<List<String>> head1(String tableName) { return listHead; } private List<List<Object>> data(String tableName) { // 表格的动态表头
List<String> head = new ArrayList<>();
// 表格内的数据
List<Map<String, Object>> dataHead = DataSelectService.findAllMap(tableName); List<List<Object>> list = new ArrayList<>(); Map<String, Object> mapData = new HashMap<>();
// 取出表头
for (int i = 0; i < dataHead.size(); i++) { mapData = dataHead.get(0); } for (String key :
mapData.keySet()) { head.add(key); } for (Map<String, Object> map :
dataHead) { List<Object> list1 = new ArrayList<>(); for (String key :
map.keySet()) { list1.add(map.get(key)); } list.add(list1); } System.out.println("list" + list); for (String s :
head) {
listHead.add(Collections.singletonList(s));
} return list; }
自定义转换器config
package com.tiancom.pas.dataSelect.config;

import com.alibaba.excel.converters.Converter;
import com.alibaba.excel.converters.WriteConverterContext;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.data.WriteCellData; import java.util.HashMap; /**
* @Author : YuanXin
* @create 2023/12/7 11:34
* @Description : 转换器
*/
public class config implements Converter<HashMap<String, Object>> { @Override
public Class<HashMap> supportJavaTypeKey() {
return HashMap.class;
} @Override
public CellDataTypeEnum supportExcelTypeKey() {
return CellDataTypeEnum.STRING;
} /**
* 这里是写的时候会调用。/
*/
@Override
public WriteCellData<HashMap<String,Object>> convertToExcelData(WriteConverterContext<HashMap<String, Object>> context) { return new WriteCellData<HashMap<String,Object>>(String.valueOf(context.getValue())); } }

easyexcel只通过表名来动态查询并动态导出数据的更多相关文章

  1. MYSQL中只知表名查询属于哪个SCHEMA

    只知道表名XXX查该表属于哪个schema.以及该表有哪些列等信息 SELECT * from information_schema.columns WHERE table_name = 'xxx'; ...

  2. sql查询所有表以及表名的模糊查询

    --1.查看所有表名:select name from sysobjects where type='U'--2.查找包含用户的表名,可通过以下SQL语句实现, Select * From sysob ...

  3. EntityFramework4.5使用Expression类创建动态查询及动态查询导航属性

    创建动态查询 想在项目中实现一个灵活的动态查询类,参考http://www.cnblogs.com/lyj/archive/2008/03/25/1122157.html和http://www.cnb ...

  4. [Database] 不知道表名和字段查找值=1234的数据.

      --如果表比较大,时间会比较长 DECLARE @searchValue NVARCHAR(50) SET @searchValue='1234' DECLARE @t TABLE ( rowNu ...

  5. PHP+Mysql+easyui点击左侧tree菜单对应表名右侧动态生成datagrid加载表单数据(二)

    关于tree菜单生成,参考我的另一篇博文地址tree 菜单 实现功能:点击左侧tree菜单中的table,右侧通过datagrid加载出该表对用的所有数据 难点:获取该表的所有列名,动态生成datag ...

  6. oracle 语句之对数据库的表名就行模糊查询,对查询结果进行遍历,依次获取每个表名结果中的每个字段(存储过程)

    语句的执行环境是plsql的sql窗口, 语句的目的是从整个数据库中的所有表判断 不等于某个字段的记录数 . 代码如下: declare s_sql clob:=''; -- 声明一个变量,该变量用于 ...

  7. 使用SQL查询所有数据库名和表名

    使用SQL查询所有数据库名和表名 MySQL中查询所有数据库名和表名 查询所有数据库 show databases; 1 1 查询指定数据库中所有表名 select table_name from i ...

  8. MySQL 查询某个数据库中所有包含数据记录的表名

    MySQL 查询某个数据库中所有包含数据记录的表名 有时根据实际应用需要,需要对数据进行备份. 如果一个数据库中有很多数据表,但是只想备份包含数据记录的那些表数据(空表不做数据备份). 如果通过如下S ...

  9. [转载] SQL获取所有数据库名、表名、储存过程以及参数列表

    查询一个数据库中所有表字段属性的sql语句       1.获取所有用户名: SELECT name FROM Sysusers where status='2' and islogin='1' is ...

  10. MySQL,SQLSERVER,ORACLE获取数据库表名及字段名

    1.MySQL 获取表名: 用“show tables”命令.在程序中也可以采用该命令获取,在返回的RowSet中的“Tables_in_db”读出来.其中“db”是指你的数据库的名称,比如说Tabl ...

随机推荐

  1. 加密原理详解:对称式加密VS非对称式加密

    一.前言 在了解加密原理前,我们来看看这样一个故事. 小红和小明是情侣,一天,小红给小明发短信说:"亲爱的,我银行卡上没有钱了,你给我转1万块吧."有过上当受骗经历的人都知道这有可 ...

  2. C语言哈希表uthash的使用方法详解(附下载链接)

    uthash简介   由于C语言本身不存在哈希,但是当需要使用哈希表的时候自己构建哈希会异常复杂.因此,我们可以调用开源的第三方头文件,这只是一个头文件:uthash.h.我们需要做的就是将头文件复制 ...

  3. SpringCloud Alibaba Security安全认证

    一. Security配置(auth认证中心) 代码地址 https://github.com/typ1805/blog-cloud Spring Security是一套安全框架,可以基于RBAC(基 ...

  4. Go ASM 学习笔记之 ppt 版

    在 小白学标准库之反射 reflect 篇中介绍了接口和反射.然而,对于接口的类型转换,底层实现还是一知半解.在参考 Go 语言设计与实现 这本书接口章节时,又看不大懂.一个拦路虎摆在面前:汇编.不懂 ...

  5. 【C++】枚举作为类函数返回值时需定义在使用之前

    枚举定义在前,作为函数返回值在后 枚举定义在后,则函数返回值需用普通类型

  6. MPC 是下一代私钥安全的7大原因

    PrimiHub一款由密码学专家团队打造的开源隐私计算平台,专注于分享数据安全.密码学.联邦学习.同态加密等隐私计算领域的技术和内容. 多重签名钱包与单一密钥钱包相比,因其提升了资产安全性,如今已成为 ...

  7. [转帖][MySQL 8.2.0] 从参数变化解读 MySQL 8.2.0 发版说明

    https://www.mryunwei.com/482476.html 日前,MySQL 8.2.0 创新版本已正式上线,并提供安装包下载,但 docker 镜像尚未更新. 在 MySQL 8.1. ...

  8. [转帖]【教程】如何在不同架构打包Docker镜像

    https://docs.qsnctf.com/qsnctf/37674.html 前言 大家在使用Docker的时候经常会遇到一个问题,就是受用机和本级不是同一架构.就比如小编使用的就是新版本的Ma ...

  9. [转帖]全表扫描却产生大量db file sequential read一例

    老熊 Oracle性能优化 2012-05-23 开发人员在进行新系统上线前的数据校验测试时,发现一条手工执行的SQL执行了超过1小时还没有返回结果.SQL很简单: SELECT * FROM MOB ...

  10. [转帖]【我和CloudQuery 的故事】安装部署CloudQuery 初体验—-前篇

    https://www.modb.pro/db/1694256553947910144 一.前言 在日常数据库运维中,为连接多种数据库,经常要安装不同的客户端,非常繁琐,且占用大量存储空间.如果能有一 ...