通过jsp向mysql批量导入数据_项目案例,将Excel数据批量导入到数据库

你在工作中是否遇到这样的问题?数据一般存放在Excel表中,逐条迁移到数据库中太麻烦,而且很多时候企业的数据量都是以万起步,单条导入显然不现实。那么该如何解决呢?

我们今天就给大家介绍一个用途非常广泛的功能:批量导入,在很多系统中,这也是必须实现的功能。而且当Excel表结构越复杂时,实现的难度就越高。

不管项目如何复杂,原理却基本相同,一般是前台页面选择Excel文件,后台获取后进行数据转化,然后循环执行Sql语句即可,了解这些原理后,一切也就变得简单。

下面为了重点演示,项目进行简化,只有批量导入功能,采用Struts2框架,将Excel数据导入到Mysql数据库中。

项目结构如下图:

Mysql数据库user表结构

Excel中数据

如果Excel中必填项数据为空,提示导入失败,报告错误信息及位置,项目演示图:

如果数据正确,提示导入数据库成功:

具体实现过程

首先是JSP页面,name的名称是重点:

上传

前台点击上传后跳转到action处理,action中首先定义:

//这里特别注意获取fileinput要和页面的导入时name属性一致。

private File fileinput;

//文件名用得到就获取,一般用不到。

private String fileinputFileName;

//下面是get和set方法,省略

然后在方法体中直接调用:

//参数为获取到的文件

ExcelUtil(fileinput);

ExcelUtil是处理Excel工具类,直接使用,代码如下:

/**解析excel 工具类*/

@SuppressWarnings("rawtypes")

public class ExcelUtil {

public FileInputStream fis ;

public HSSFWorkbook workBook;

public HSSFSheet sheet;

public XMLUtil parseXmlUtil;

public StringBuffer errorString;

/**当前实体类的code**/

public String curEntityCode;

/**表头map对象:key:entityCode, value:headMap(index,headTitle)**/

public Map curEntityHeadMap ;

/**字段的必填:key:entityCode+headTitle, value:true(必填),false(不必填)**/

public Map curEntityColRequired;

/**存放每一行的数据**/

public  List listDatas ;

public ExcelUtil(File excelFile){

try {

if(excelFile == null){

throw new FileNotFoundException();

}

fis = new FileInputStream(excelFile);

workBook = new HSSFWorkbook(fis);

parseXmlUtil = new XMLUtil();

errorString = new StringBuffer();

readExcelData();

} catch (FileNotFoundException e) {

e.printStackTrace();

}catch (IOException e) {

e.printStackTrace();

}

}

/**开始从excel读取数据**/

public void readExcelData(){

int sheetSize = workBook.getNumberOfSheets();

for(int i=0;i

sheet = workBook.getSheetAt(i);

String entityName = workBook.getSheetName(i);

readSheetData(sheet,entityName);

}

}

/**读每个sheet页的数据**/

public void readSheetData(HSSFSheet sheet,String entityName){

int rowNumbers = sheet.getPhysicalNumberOfRows();

Map ent = (Map) parseXmlUtil.getEntityMap().get(entityName);

this.setCurEntityCode((String) ent.get("code"));

if(rowNumbers == 0){

System.out.println("excel中数据为空!");

errorString.append(Constans.ERROR_EXCEL_NULL);

}

List colList = (List) parseXmlUtil.getColumnListMap().get(entityName);

int xmlRowNum = colList.size();

HSSFRow excelRow = sheet.getRow(0);

int excelFirstRow = excelRow.getFirstCellNum();

int excelLastRow = excelRow.getLastCellNum();

if(xmlRowNum  != (excelLastRow-excelFirstRow)){

System.out.println("xml列数与excel列数不相符,请检查");

errorString.append(Constans.ERROR_EXCEL_COLUMN_NOT_EQUAL);

}

readSheetHeadData(sheet);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现JSP页面中的表单信息保存到MySQL数据库,可以使用Java JDBC API来连接数据库,并执行SQL语句来插入表单数据。具体步骤如下: 1. 在JSP页面中,使用HTML表单元素来收集用户输入的数据。 2. 在JSP页面中,使用Java代码来获取表单数据,并将其存储到Java变量中。 3. 在JSP页面中,使用Java JDBC API来连接MySQL数据库,并创建一个PreparedStatement对象来执行插入数据的SQL语句。 4. 在JSP页面中,将存储在Java变量中的表单数据绑定到PreparedStatement对象的参数中,并执行SQL语句来将数据插入到MySQL数据库中。 下面是一个JSP页面保存表单数据MySQL数据库的示例代码: ``` <%@page import="java.sql.*"%> <% // 获取表单数据 String name = request.getParameter("name"); String email = request.getParameter("email"); // 连接MySQL数据库 String url = "jdbc:mysql://localhost:3306/mydatabase"; String user = "root"; String password = "mypassword"; Connection conn = DriverManager.getConnection(url, user, password); // 创建PreparedStatement对象并执行SQL语句 String sql = "INSERT INTO users (name, email) VALUES (?, ?)"; PreparedStatement stmt = conn.prepareStatement(sql); stmt.setString(1, name); stmt.setString(2, email); stmt.executeUpdate(); // 关闭数据库连接 stmt.close(); conn.close(); %> ``` 在上面的示例代码中,我们使用了Java JDBC API来连接MySQL数据库,并使用PreparedStatement对象来执行插入数据的SQL语句。通过将表单数据绑定到PreparedStatement对象的参数中,我们可以避免SQL注入攻击,并且可以更安全地将数据保存到MySQL数据库中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值