JDBC는 EXCEL 데이터를 데이터베이스에 저장합니다(3.POI는 Excel 데이터를 데이터베이스에 저장합니다).
2.java
import java.io.File;
import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
public class ExcelToDB {
/**
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
ExcelToDB db = new ExcelToDB();
db.excelToDB();
}
public void excelToDB() throws Exception{
String filePath = "D:\\student.xls";
File file = new File(filePath);
if(!file.exists() || !file.canRead()){
System.out.println(" ");
return;
}
POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(filePath));
// Workbook
HSSFWorkbook wb = new HSSFWorkbook(fs);
// get Sheet
Sheet sheet = wb.getSheetAt(0);
//
Row srow = sheet.getRow(1);
if (srow == null){
return;
}
//
int columnLength = 2;
List<Student> list = new ArrayList<Student>();
Student stu = null;
for (int i = 1; i < sheet.getPhysicalNumberOfRows(); i++) {
Row row = sheet.getRow(i);
stu = new Student();
ArrayList<String> data = getRowData(row,columnLength);
int k = 0;
String id = data.get(k++).trim(), name = data.get(k++).trim();
stu.setId(id);
stu.setName(name);
list.add(stu);
}
saveDatoToDB(list);
}
/**
*
* @param list
*/
private void saveDatoToDB(List<Student> list){
Connection conn = JDBCUtilSingle.getInstance().getConnection();
try {
PreparedStatement st= conn.prepareStatement("insert into student(id,name) values(?,?)");
for(Student stu : list){
st.setString(1, stu.getId());
st.setString(2, stu.getName());
st.addBatch();
}
st.executeBatch();
JDBCUtilSingle.getInstance().closeConnection(null, st, conn);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* Excel
*/
private ArrayList<String> getRowData(Row row, int len){
ArrayList<String> data = new ArrayList<String>();
for(int j=0; j<len; j++){
Cell c = row.getCell(j);
String v;
if(c==null){
data.add("");
continue;
}
switch(c.getCellType()){
case Cell.CELL_TYPE_BLANK:
v = "";
break;
default:
v = c.toString().trim();
break;
}
data.add(v);
}
return data;
}
}
데모 다운로드 주소
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
SQLite의 query로 망설임이것은 내가 처음 안드로이드 응용 프로그램 개발에서 망설이고, 그 후 해결 된 방법을 비망록으로 철자하고 있습니다. java에서 SQLite를 이용한 애플리케이션을 작성하는 동안 EditText에 입력된 item이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.