Servlet读取Excel标准化数据库过程记录

时间:2023-03-10 02:47:42
Servlet读取Excel标准化数据库过程记录

完成数据库的连接

  Servlet读取Excel标准化数据库过程记录

获取连接参数

  Servlet读取Excel标准化数据库过程记录

  Servlet读取Excel标准化数据库过程记录

拷贝1.数据库URL 2.驱动程序类 3.用户

编写Servlet

  1.创建连接对象

 Connection con = null;
PreparedStatement prst = null;
ResultSet rs = null;

 

  2.写入连接参数

   String url = "数据库URL";
String driver = "驱动程序类";
String user = "用户";
String password = "数据库用户密码";

 

  3.连接数据库,编写sql语句

 Class.forName(driver)
con = DriverManager.getConnection(url,user,password);
String sql = "UPDATE [表] SET [目标列]=? WHERE [目标列]=?";

  4.读取execel

 Workbook book = Workbook.getWorkbook(new File("文件路径"));
Sheet sheet = book.getSheet(工作表序号);

  5.写一个for循环

 //一个整型,注意excel从第几行开始是更新值,注意范围设置,i++
for (int i = 1; i < 215; i++) {
// 使用jxl包,读取单元格(列序号,行序号)
jxl.Cell cell0 = sheet.getCell(0, i);
jxl.Cell cell1 = sheet.getCell(1, i);
//声明变量,取单元格的文本内容
String result0 = cell0.getContents();
String result1 = cell1.getContents();
//编译预编译语句,将两个单元格内容传入sql语句
prst = con.prepareStatement(sql);
// 注意位置(数字表示第几个问号,传入变量)
prst.setString(2, result0);
prst.setString(1, result1);
//执行sql语句
prst.executeUpdate();
}

  6.关掉excel读取

 book.close();

完整代码

 protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
Connection con = null;
PreparedStatement prst = null;
ResultSet rs = null;
String url = "jdbc:sqlserver://localhost:***;databaseName=***";
String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
String user = "sa";
String password = "***";
try {
Class.forName(driver);
con = DriverManager.getConnection(url, user, password);
String sql = "UPDATE [***] SET [***]=? WHERE [***]=? ";
Workbook book = Workbook.getWorkbook(new File("****"));
Sheet sheet = book.getSheet(*);
//一个整型,注意excel从第几行开始是更新值,注意范围设置,i++
for (int i = *; i <***; i++) {
// 使用jxl包,读取单元格(列序号,行序号)
jxl.Cell cell0 = sheet.getCell(0, i);
jxl.Cell cell1 = sheet.getCell(1, i);
//声明变量,取单元格的文本内容
String result0 = cell0.getContents();
String result1 = cell1.getContents();
//编译预编译语句,将两个单元格内容传入sql语句
prst = con.prepareStatement(sql);
// 注意位置(数字表示第几个问号,传入变量)
prst.setString(2, result0);
prst.setString(1, result1);
//执行sql语句
prst.executeUpdate();
}
out.print("<h1><strong>成功!</strong></h1>");
book.close();
} catch (BiffException ex) {
Logger.getLogger(doH.class.getName()).log(Level.SEVERE, null, ex);
} catch (ClassNotFoundException ex) {
Logger.getLogger(doH.class.getName()).log(Level.SEVERE, null, ex);
} catch (SQLException ex) {
Logger.getLogger(doH.class.getName()).log(Level.SEVERE, null, ex);
}
}

注意事项:

  1.该方法用的jxl的包,需要在库中导入

  Servlet读取Excel标准化数据库过程记录

  2.操作数据库需要try{}catch 来抛出异常,先码

Class.forName(driver);

  处理方式

  Servlet读取Excel标准化数据库过程记录

接着码

prst = conn.prepareStatement(sql);

添加catch子句Servlet读取Excel标准化数据库过程记录