jsp后台批量导入excel表格数据到mysql中_运用java解析excel表,拿到表中的数据并批量插入数据库...

首先,本文是运用jxl进行excel表的解析,所以我们需要先下载一个jxl.jar的jar包;

并且需要一个与excel表对应的实体类,用于接收excel的数据;

然后就是代码部分,我们先编写一个函数,用于读取excel;

该函数会返回execl中的数据,将数据一个一个写入innerList,再将innerList写入outerList

最后返回outerList

public List readExcel(File file) {

try {

// 创建输入流,读取Excel

InputStream is = new FileInputStream(file.getAbsolutePath());

// jxl提供的Workbook类

Workbook wb = Workbook.getWorkbook(is);

// Excel的页签数量

int sheet_size = wb.getNumberOfSheets();

for (int index = 0; index < sheet_size; index++) {

List outerList=new ArrayList();

// 每个页签创建一个Sheet对象

Sheet sheet = wb.getSheet(index);

// sheet.getRows()返回该页的总行数

for (int i = 0; i < sheet.getRows(); i++) {

List innerList=new ArrayList();

// sheet.getColumns()返回该页的总列数

for (int j = 0; j < sheet.getColumns(); j++) {

String cellinfo = sheet.getCell(j, i).getContents();

if(cellinfo.isEmpty()){

continue;

}

innerList.add(cellinfo);

}

outerList.add(i, innerList);

}

return outerList;

}

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (BiffException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

return null;

}

然后再编写一个函数将文件的路径给解析函数,然后就可以根据解析函数返回的outerList进行循环查看表中的数据;

下面的函数中,直接将拿到的数据赋值给一个对象,然后直接给另一个与数据库连接的UserService_sadmin()类中的leading方法插入数据库。

private void leading_in() {

List u=new ArrayList();

File file = new File("G:/jifangstudent/temp/student.xls");//需要解析的excel表,注意表的格式必须为xls

List excelList = readExcel(file);

for (int i = 1; i < excelList.size(); i++) {//循环遍历List中的内容

List list = (List) excelList.get(i);

int j = 0;

if(j < list.size()) {

User user=new User();//新建一个对象,将数据循环赋值给对象

user.setUsername(list.get(0).toString());

user.setPassword(list.get(1).toString());

user.setNo(list.get(2).toString());

user.setName(list.get(3).toString());

user.setSex(list.get(4).toString());

user.setDepartment(list.get(5).toString());

user.setTelephone(list.get(6).toString());

user.setEmail(list.get(7).toString());

user.setUsertype(list.get(8).toString());

j=10;

u.add(user);//每解析一行即可得到一个对象,再将对象写到List中

}

}

boolean success=new UserService_sadmin().leading(u);//调用函数,进行数据库中数据的插入操作

}

  • 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、付费专栏及课程。

余额充值