文件上传EXCEL怎么直接存储到数据库里

文件上传EXCEL怎么直接存储到数据库里,第1张

明白啥指定json我建议:

1、STRUTS文件标签选择并传EXCEL文件示例代码

请选择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、将上传的文件转换为二进制流,并将其插入到数据库中。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10087958.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存