请选择Excel文件(.):
Excel文件标题(表)占行:
2、UploadExcelFileAction接收、写入台指定目录(局部代码)
FileOutputStream fos = null
try {
//文件数据(数组)
byte[] fileDate = ff.getFileData()
//服务器硬盘文件夹绝路径
ServletContext application = this.getServlet().getServletContext()
String realPath = application.getRealPath("/")
if(excelType==null||excelType.equals("xlsx"))//默认2007版本格式
fos = new FileOutputStream(realPath+"aircraftExcelTable.xlsx")
else
fos = new FileOutputStream(realPath+"aircraftExcelTable.xls")
fos.write(fileDate)
fos.close()
if(excelType==null||excelType.equals("xlsx"))//默认2007版本格式
num=ReadExcelSaveToDB.ReadAndSaveNew(realPath+"aircraftExcelTable.xlsx",topicNumber)
else
num=ReadExcelSaveToDB.ReadAndSave(realPath+"aircraftExcelTable.xls",topicNumber)
if(num==-1){
session.setAttribute("forwardPage", currentPage)
session.setAttribute("prompt", "文件传输失败或连接数据库")
return mapping.findForward("promptpage")
}else if(num==-2){
session.setAttribute("forwardPage", currentPage)
session.setAttribute("prompt", "Excel文件于1000条或能识别重新制作Excel文件")
return mapping.findForward("promptpage")
}else if(num==-3){
session.setAttribute("forwardPage", currentPage)
session.setAttribute("prompt", "Excel文件包含非字符(非数字)请修重试")
return mapping.findForward("promptpage")
}
} catch (FileNotFoundException e) {
e.printStackTrace()
} catch (IOException e) {
e.printStackTrace()
}finally{
try {
fos.close()
} catch (IOException e) {
e.printStackTrace()
}
}
3、解析读取表数据(POI)并存入数据库(局部代码)
public static int ReadAndSave(String path,String topicNumber){
try {
File file=new File(path)
FileInputStream fs=new FileInputStream(file)
@SuppressWarnings("resource")
HSSFWorkbook workbook=new HSSFWorkbook(fs)
//共几张表
int sheet_num=workbook.getNumberOfSheets()
setSheetNumber(0)
setProcess(0)//始
//循环每表
for(int i=0i<sheet_numi++){
HSSFSheet sheet=workbook.getSheetAt(i)
setSheetNumber(i+1)
if(sheet!=null&&sheet.getPhysicalNumberOfRows()!=0){
int topicNumberNum=Integer.parseInt(topicNumber)//越首行标题()
totalNumber=sheet.getPhysicalNumberOfRows()-topicNumberNum
//循环各行
for(int j=sheet.getFirstRowNum()+topicNumberNumj<=sheet.getPhysicalNumberOfRows()j++){
HSSFRow row=sheet.getRow(j)
String aircraft=null
//String aircraftType=null
Double takeoffWeight=0.00
Double payloadMax2=0.00
int seatNumberMax2=0
if(row!=null&&row.getPhysicalNumberOfCells()!=0){
switch(row.getCell(0).getCellType()){
case Cell.CELL_TYPE_STRING:
aircraft=(row.getCell(0).getStringCellValue()).trim()
break
case Cell.CELL_TYPE_NUMERIC:
aircraft=String.valueOf(row.getCell(0).getNumericCellValue()).trim()
break
}
//继续处理其单元格、行
}
//存入数据库
AircraftTableActionForm atb=new AircraftTableActionForm()
if(aircraft!=null&&!aircraft.equals("")){
atb.setAircraft(aircraft)
//set其值
updateByExcel(atb)!=-1
}
}
您好,ResultSet得相关参数代码片断,下面的代码对类型判断和转换还不全面,如果还有其他字段请自行添加
Java代码
try {
ResultSetMetaData meta = rs.getMetaData()
int columnCount = meta.getColumnCount()
strutName = new String[columnCount]
strutType = new byte[columnCount]
rs.last()
int itemCount = rs.getRow()
rs.first()
data = new Object[itemCount][columnCount]
for (int i = 1i <= columnCounti++){
int type = (byte) meta.getColumnType(i)
//2是BigDecimal
if(type == 2){
strutType[i-1] = DBFField.FIELD_TYPE_N
}
//12是String
else if(type == 12){
strutType[i-1] = DBFField.FIELD_TYPE_C
}
//91是java.util.Date
else if(type == 91){
strutType[i-1] = DBFField.FIELD_TYPE_D
}
strutName[i-1] = meta.getColumnName(i)
}
for (int i = 0rs.next()i++){
for (int j = 0j <columnCountj++){
Object da = rs.getObject(j+1)
if(da instanceof BigDecimal){
Double d = Double.parseDouble(da.toString())
data[i][j] = d
}else{
data[i][j] = da
}
}
}
}catch (Exception e){
e.printStackTrace()
}finally{
rs = null
}
上面采用的是传统方法进行导出dbf文件,如果大数据量导出时,就要先将文件生成到服务器端,然后从response里拿输入流,将刚生成的文件写到客户端,也就是多一个文件流写入的过程。
1、创建需要的表格,包括文件名、文件类型、文件内容和上传时间等字段。2、在Java项目中引入相关的数据库驱动程序,以实现与达梦数据库的连接。
3、创建一个包含文件上传表单的HTML页面,并且在后端使用Java代码接收上传的文件。
4、将上传的文件转换为二进制流,并将其插入到数据库中。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)