無論是作軟件仍是作網站,相信不少人在作的時候都要用到數據庫,而數據庫的數據從何而來呢,可使手動添加的,可是大多數狀況下咱們使用的是已有的數據,咱們想借助開發的工具管理目前已有的數據,若是是小量的數據,手動錄入也無妨,可是對於大量數據呢,手動錄入顯然已經不顯示,並且,更多的時候,咱們呢想在軟件上增長一個數據的批量導入,這樣無論是誰在用這款軟件,均可以方便的管理已有數據,那麼咱們最經常使用的數據管理器是什麼呢,毫無疑問Excel,可是咱們作軟件是幾乎沒有人會使用Excel做爲DB,因此咱們遇到的問題就是如何在軟件中實現數據批量導入,數據源是Excel,有人會說用ODBC啊,能夠導入到任何地方,可是這種作法好像沒有什麼技術含量,並且讓用戶沒次批量導入的時候都設置一個ODBC數據源是不現實的,今天博主將給你們介紹用春java實現讀取Excel數據文件放入Access數據庫(各個數據庫的原理是同樣的),咱們用到的是一個開源API,jxl,代碼以下:java
public static boolean readExcel(String filePath){
boolean success=false;
Workbook rwb = null;
try{
InputStream is = new FileInputStream(filePath);
rwb = Workbook.getWorkbook(is);
// 獲取第一張Sheet表
Sheet rs = rwb.getSheet(0);
for (int k = 1; k < rs.getRows(); k++){
String major=rs.getCell(0, k).getContents();
String year=rs.getCell(1,k).getContents();
String class1=rs.getCell(2, k).getContents();
String number1=rs.getCell(3, k).getContents();
String name=rs.getCell(4, k).getContents();
String sex=rs.getCell(5, k).getContents();
String people=rs.getCell(6, k).getContents();
String area=rs.getCell(7, k).getContents();
String birth=rs.getCell(8, k).getContents();
String bodyid=rs.getCell(9, k).getContents();
String phone=rs.getCell(10, k).getContents();
String hostel=rs.getCell(11, k).getContents();
String father=rs.getCell(12, k).getContents();
String mather=rs.getCell(13, k).getContents();
String tel=rs.getCell(14, k).getContents();
String studentstate=rs.getCell(15, k).getContents();
String level1=rs.getCell(16, k).getContents();
String party=rs.getCell(17, k).getContents();
String duties=rs.getCell(18, k).getContents();
String english=rs.getCell(19, k).getContents();
String computer=rs.getCell(20, k).getContents();
String address=rs.getCell(21, k).getContents();
String personstation=rs.getCell(22, k).getContents();
String fundingstation=rs.getCell(23, k).getContents();
String awardstation=rs.getCell(24, k).getContents();
String punishmentstation=rs.getCell(25,k).getContents();
String other1=rs.getCell(26, k).getContents();
String picturepath="";
if(major.equals("")||class1.equals("")||name.equals("")||number1.equals("")){
success=false;
break;
}else{
String str1="insert intoinformation(major,year,class1,number1,name,sex,people,area,birth,bodyid,phone,hostel,father,mather,tel,studentstate,level1,party,duties,english,computer,address,personstation,fundingstation,awardstation,punishmentstation,other1,picturepath)values('"+major+"','"+year+"','"+class1+"','"+number1+"','"+name+"','"+sex+"','"+people+"','"+area+"','"+birth+"','"+bodyid+"','"+phone+"','"+hostel+"','"+father+"','"+mather+"','"+tel+"','"+studentstate+"','"+level1+"','"+party+"','"+duties+"','"+english+"','"+computer+"','"+address+"','"+personstation+"','"+fundingstation+"','"+awardstation+"','"+punishmentstation+"','"+other1+"','"+picturepath+"')";
CommonCode.addInfo(str1);
CommonCode.closeAll();
success=true;
}
}
rwb.close();
}catch (Exception e){
e.printStackTrace();
}
return success;數據庫
} 工具