该例主要实现了将excel的值导入到mysql数据库当中来,为了方便将数据库的值都改了varchar类型,实现的比较粗糙,仅供参考。
所用jar包:
mysql-connector-java-5.1.7-bin.jar
jxl.jar
commons-logging-1.0.4.jar
commons-lang-2.3.jar
import java.io.File;
import java.io.IOException;
import java.sql.Date;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;
import jxl.Cell;
import jxl.CellType;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableCell;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class ReadWriteExcelUtil {
/**
* @param args
*/
public static void main(String[] args) {
String fileName = "d:" + File.separator + "其他.xls";
List list = ReadWriteExcelUtil.readExcel(fileName);
DBUtil.batch(list);
}
/**
* 從excel文件中讀取所有的內容
*
* @param file
* excel文件
* @return excel文件的內容
*/
public static List<Zhaopin> readExcel(String fileName) {
List list = new ArrayList();
Workbook wb = null;
try {
// 构造Workbook(工作薄)对象
wb = Workbook.getWorkbook(new File(fileName));
} catch (BiffException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
if (wb == null)
return null;
// 获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
Sheet[] sheet = wb.getSheets();
if (sheet != null && sheet.length > 0) {
// 对每个工作表进行循环
for (int i = 0; i < sheet.length; i++) {
// 得到当前工作表的行数
int rowNum = sheet[i].getRows();
for (int j = 1; j < rowNum; j++) {
// 得到当前行的所有单元格
Cell[] cells = sheet[i].getRow(j);
ArrayList temp = new ArrayList();
if (cells != null && cells.length > 0) {
// 对每个单元格进行循环
for (int k = 0; k < cells.length; k++) {
// 读取当前单元格的类型
CellType type = cells[i].getType();
// 读取当前单元格的值
String cellValue = cells[k].getContents();
temp.add(k, formateDate(type, cellValue));
}
}
list.add(temp);
// sb.append("\r\n");
}
// sb.append("\r\n");
}
}
// 最后关闭资源,释放内存
wb.close();
return list;
}
/**
* 该方法将日期格式转换为想要的格式
*
* @param type
* 单元格的类型
* @param value
* 单元格的值
* @return
*/
public static String formateDate(CellType type, String value) {
String str = value;
if (CellType.DATE == type) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
try {
Date dd = (Date) sdf.parse(value.toString());
return sdf.format(dd);
} catch (ParseException e) {
}
}
return str;
}
/**
* 把內容寫入excel文件中
*
* @param fileName
* 要寫入的文件的名稱
*/
public static void writeExcel(String fileName) {
WritableWorkbook wwb = null;
try {
// 首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象
wwb = Workbook.createWorkbook(new File(fileName));
} catch (IOException e) {
e.printStackTrace();
}
if (wwb != null) {
// 创建一个可写入的工作表
// Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置
WritableSheet ws = wwb.createSheet("sheet1", 0);
// 下面开始添加单元格
for (int i = 0; i < 10; i++) {
for (int j = 0; j < 5; j++) {
// 这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行
Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第"
+ (j + 1) + "列");
// Label labelC=new Label();
try {
// 将生成的单元格添加到工作表中
ws.addCell((WritableCell) labelC);
} catch (RowsExceededException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
}
}
try {
// 从内存中写入文件中
wwb.write();
// 关闭资源,释放内存
wwb.close();
} catch (IOException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
}
}
}
bean
public class Zhaopin {
private int id;
private String qudao;
private String laiyuan;
private String ispay;
private String posttime;
private String fuzeren;
private String gangwei;
private String name;
private String sex;
private String age;
private String xueli;
private String phone;
private String email;
private String salary;
private String addr;
//...setter()/getter()
}
DBUtil
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
public class DBUtil {
private static String user = "root";
private static String passwd = "root1230";
private static String driverClass = "com.mysql.jdbc.Driver";
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName(driverClass);
conn = DriverManager.getConnection(
"jdbc:mysql://127.0.0.1:3306/test", user, passwd);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
public static void releaseConn(Connection conn, PreparedStatement ps,
ResultSet rs) {
try {
if (conn != null) {
conn.close();
}
if (ps != null) {
ps.close();
}
if (rs != null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
public static void batch(List list) {
String sql = "insert into tb_zhaopin(qudao,laiyuan,ispay,posttime,fuzeren,gangwei,name,sex,age,xueli,phone,email,salary,addr)values(?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
conn = DBUtil.getConnection();
conn.setAutoCommit(false);
ps = conn.prepareStatement(sql);
ArrayList list2=null;
int count=0;
for (int i = 0; i < list.size(); i++) {
list2 = (ArrayList) list.get(i);
if (list2 != null) {
for(int j=0;j<list2.size();j++){
ps.setString(j+1, (String) list2.get(j));
}
ps.addBatch();
count++;
if((count+500)%500==0){
ps.executeBatch();
ps.clearBatch();
count=1;
conn.commit();
}
}
}
//判断是否有剩余的没有被处理的.
if(count%500!=0){
ps.executeBatch();
ps.clearBatch();
conn.commit();
}
} catch (Exception e) {
e.printStackTrace();
} finally {
DBUtil.releaseConn(conn, ps, rs);
}
}
}
所用的excel表格:
sql语句:
CREATE TABLE `tb_zhaopin` (
`id` int(12) NOT NULL AUTO_INCREMENT,
`qudao` varchar(20) DEFAULT NULL,
`laiyuan` varchar(20) DEFAULT NULL,
`ispay` varchar(12) DEFAULT NULL,
`posttime` varchar(12) DEFAULT NULL,
`fuzeren` varchar(20) DEFAULT NULL,
`gangwei` varchar(20) DEFAULT NULL,
`name` varchar(20) DEFAULT NULL,
`sex` varchar(20) DEFAULT NULL,
`age` varchar(12) DEFAULT NULL,
`xueli` varchar(20) DEFAULT NULL,
`phone` varchar(12) DEFAULT NULL,
`email` varchar(20) DEFAULT NULL,
`salary` varchar(12) DEFAULT NULL,
`addr` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8;