主要应用技术:poi + betwixt + reflect

一、实际应用过程

1.创建与目标表结构一样,表名为‘{目标表名}_import’的临时表;

2.创建用于存储导入问题数据的表:t_import_error (只需创建一张);

Name Code Data Type Length Precision Mandatory Primary Identifier Displayed Domain
问题id op_id VA36 36 TRUE TRUE TRUE <None>
问题表名 op_name VA50 50 TRUE FALSE TRUE <None>
所在行号 row_no I TRUE FALSE TRUE <None>
问题说明 memo TXT TRUE FALSE TRUE <None>
创建人id create_id VA36 36 TRUE FALSE TRUE <None>
创建人名 create_name VA50 50 TRUE FALSE TRUE <None>
创建时间 create_time VA17 17 TRUE FALSE TRUE <None>

3.创建WEB-INF/excel/{目标表名}_import.xml 配置文件

<?xml version="1.0" encoding="GBK"?>
<importExcel>
<name>台帐明细导入</name>
<!--initSQL 对excel数据进行库表操作之前执行的初始化语句,多条语句用";"分隔 , ${userId} 标识当前登录用户id, 本语句为清除上次导入发现的问题数据-->
<initSQL>delete from t_import_error where create_id='${userId}'</initSQL>
<!--beforeSaveSQL excel数据由_import临时表转入正式表之前执行的语句,多条语句用";"分隔,${userId} 标识当前登录用户id,可执行删除重复数据等-->
<beforeSaveSQL>delete from t_account_detail</beforeSaveSQL>
<!--afterSaveSQL excel数据由_import临时表转入正式表之后执行的语句,多条语句用";"分隔,${userId} 标识当前登录用户id-->
<afterSaveSQL>delete from t_account_detail_import where create_id='${userId}'</afterSaveSQL>
<!-- excelColumn excel显式列名定义 -->
<excelColumn>
<entry>
<!-- key excel列名 -->
<key>事项名称</key>
<value>
<!--column 数据库字段名-->
<column>op_name</column>
<!--dataType 数据类型 目前支持 varchar、int、float 三种类型-->
<dataType>varchar</dataType>
<!--length 数据库字段长度, 0表示不限制-->
<length>255</length>
<!--required 是否必填 true、false -->
<required>true</required>
<!--transfer 是否进行数据内容转换 true(需配置<className>、<method>、<param>节点)、false -->
<transfer>false</transfer>
</value>
</entry>
<entry>
<key>台帐分类</key>
<value>
<column>type_id</column>
<dataType>varchar</dataType>
<length>100</length>
<required>true</required>
<transfer>true</transfer>
<!--className 负责数据转换的类-->
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<!--method 负责数据转换的方法名, 如果要设置字段默认值统一使用 getConst方法并由param设置默认值-->
<method>getAccoutTypeIdByName</method>
<!--param 负责数据转换的方法对应的参数,
多个参数用","分隔 如<param>${self},varchar:nodeId,int:3,float:15.2</param>,${self}表示读取自身excel表格内容-->
<param>${self}</param>
</value>
</entry>
<entry>
<key>开始日期</key>
<value>
<column>begin_date</column>
<dataType>date</dataType>
<length>8</length>
<required>true</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>filterDate</method>
<param>${self}</param>
</value>
</entry>
<entry>
<key>结束日期</key>
<value>
<column>end_date</column>
<dataType>date</dataType>
<length>8</length>
<required>true</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>filterDate</method>
<param>${self}</param>
</value>
</entry>
<entry>
<key>数据值</key>
<value>
<column>detail_value</column>
<dataType>float</dataType>
<length>15</length>
<required>true</required>
<transfer>false</transfer>
</value>
</entry>
<entry>
<key>描述</key>
<value>
<column>describe</column>
<dataType>varchar</dataType>
<length>0</length>
<required>false</required>
<transfer>false</transfer>
</value>
</entry>
</excelColumn>
<!-- systemColumn 系统隐式列名定义 -->
<systemColumn>
<entry>
<key>台帐id</key>
<value>
<column>op_id</column>
<dataType>varchar</dataType>
<length>36</length>
<required>true</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>getUUID</method>
<param></param>
</value>
</entry>
<entry>
<key>创建人id</key>
<value>
<column>create_id</column>
<dataType>varchar</dataType>
<length>36</length>
<required>true</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>getUserId</method>
<param></param>
</value>
</entry>
<entry>
<key>创建人名</key>
<value>
<column>create_name</column>
<dataType>varchar</dataType>
<length>50</length>
<required>true</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>getUserName</method>
<param></param>
</value>
</entry>
<entry>
<key>创建时间</key>
<value>
<column>create_time</column>
<dataType>varchar</dataType>
<length>17</length>
<required>true</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>getNowInput</method>
<param></param>
</value>
</entry>
<entry>
<key>修改人id</key>
<value>
<column>modify_id</column>
<dataType>varchar</dataType>
<length>36</length>
<required>false</required>
<transfer>true</transfer>
<className>com.egeniuss.jxibs.manage.importexcel.Transfer</className>
<method>getConst</method>
<param>varchar:admin</param>
</value>
</entry>
</systemColumn>
</importExcel>

4.页面传参即可使用

<input type="hidden" name="tableTarget" value="t_account_detail"/>

<input type="file" name="excel"/>

java基于xml配置的通用excel单表数据导入组件(一、实际应用过程)的更多相关文章

  1. java基于xml配置的通用excel单表数据导入组件(四、DAO主处理类)

    package XXXXX.manage.importexcel; import java.beans.IntrospectionException; import java.io.BufferedR ...

  2. java基于xml配置的通用excel单表数据导入组件(二、xml配置文件解析加载)

    1.BN_ImportExcel.java 对应xml主节点属性 package XXXXX.manage.importexcel; import java.io.Serializable; impo ...

  3. java基于xml配置的通用excel单表数据导入组件(五、Action处理类)

    package xxxxxx.manage.importexcel; import java.io.File; import java.util.HashMap; import java.util.M ...

  4. java基于xml配置的通用excel单表数据导入组件(三、负责数据转换处理的类)

    package xxxxxxx.manage.importexcel; import java.util.Map; import java.util.logging.Logger; import xx ...

  5. [刘阳Java]_Spring AOP基于XML配置介绍_第9讲

    基于注解配置的Spring AOP固然简单,但是这节我们会给大家介绍基于XML配置的AOP是如何应用的.为什么这么说了,因为后面我们还会介绍到Spring对Dao操作的事务管理(基于AOP的XML文件 ...

  6. Sping MVC不使用任何注解处理(jQuery)Ajax请求(基于XML配置)

    1. Spring Spring框架是一个轻量级的解决方案,是一个潜在的一站式商店,用于构建企业就绪的应用程序.Spring框架是一个Java平台,为开发Java应用程序提供全面的基础架构支持.Spr ...

  7. 转载 - Struts2基于XML配置方式实现对action的所有方法进行输入校验

    出处:http://www.cnblogs.com/Laupaul/archive/2012/03/15/2398360.html http://www.blogjava.net/focusJ/arc ...

  8. 【Spring Framework】Spring入门教程(二)基于xml配置对象容器

    基于xml配置对象容器--xml 标签说明 alias标签 作用:为已配置的bean设置别名 --applicationContext.xml配置文件 <?xml version="1 ...

  9. struts_20_对Action中所有方法、某一个方法进行输入校验(基于XML配置方式实现输入校验)

    第01步:导包 第02步:配置web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app ...

随机推荐

  1. Deep Learning 学习随记(三)Softmax regression

    讲义中的第四章,讲的是Softmax 回归.softmax回归是logistic回归的泛化版,先来回顾下logistic回归. logistic回归: 训练集为{(x(1),y(1)),...,(x( ...

  2. 关于IOS网络通信的学习

    最近由于需要在看关于网络通信方面的知识,所以在网上找了找关于网络解释方面的知识.找了半天没有找到一篇能详细解释通讯流程的,心里忍不住就万马奔腾了.没办法,谁让自己想学呢!于是又找了找,觉得没有满意的. ...

  3. Runtime 在IOS中的详细使用

    因为之前写东西的时候,都在未知笔记中,所有大家没有看到过我的文章,今天就开始使用博客园来进行和大家沟通.好了,废话不那么多了,转入正题.下面我把runtime 给大家介绍一下. ### 一.runti ...

  4. let和const====均参考阮大神的es6入门

    // 解构复制// let [foo,[[bar],baz]] = [1,[[2],3]];// console.log(foo);//1// console.log(bar);//2// conso ...

  5. hdu 1286 找新朋友 (欧拉函数)

    Problem Description 新年快到了,"猪头帮协会"准备搞一个聚会,已经知道现有会员N人,把会员从1到N编号,其中会长的号码是N号,凡是和会长是老朋友的,那么该会员的 ...

  6. OpenJudge/Poj 1517 u Calculate e

    1.链接地址: http://bailian.openjudge.cn/practice/1517 http://poj.org/problem?id=1517 2.题目: 总时间限制: 1000ms ...

  7. 配置php连接apache

    配置php连接apache 1.安装php所需要的库 yum install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel li ...

  8. centOS tengine 安装后 不能访问的问题

    1 安装方式跟在ubuntu下 安装一样.因为都是用源码 2  但安装好以后发现,局域网电脑访问不了!.原以为是安装错了.又装了一遍,还是不行,最终是iptables 没开放80端口... http: ...

  9. problem 1 -- Two sum

    很简单.没什么好说的.但是在阿里实习的第四面的时候居然问到了. 大意是给出一组无序数列和目标数Z,在无序数列中找到X和Y,使得X+Y=Z. 有两种方法: 一种是排序后,同时首尾搜索.时间复杂度为O(n ...

  10. Sass 编译的几种方法

    常常有人会问,使用 Sass 进行开发,那么是不是直接通过“<link>”引用“.scss”或“.sass”文件呢? 那么这里告诉大家,在项目中还是引用“.css”文件,Sass 只不过是 ...