java导出数据库的全部表到excel
本文实例为大家分享了java将某个数据库的表全部导出到excel中的方法,供大家参考,具体内容如下
第一步:如何用POI操作Excel
@Test
publicvoidcreateXls()throwsException{
//声明一个工作薄
HSSFWorkbookwb=newHSSFWorkbook();
//声明表
HSSFSheetsheet=wb.createSheet("第一个表");
//声明行
HSSFRowrow=sheet.createRow(7);
//声明列
HSSFCellcel=row.createCell(3);
//写入数据
cel.setCellValue("你也好");
FileOutputStreamfileOut=newFileOutputStream("d:/a/b.xls");
wb.write(fileOut);
fileOut.close();
}
第二步:导出指定数据库的所有表
分析:
1:某个数数据库有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,newString[]{Table}); -excel的文件名称。
2:对每一个表进行select*操作。-每一个sheet的名称。
3:分析表结构,rs.getMetadate();ResultSetMedated
4:多个列,列名是什么.-字段名就是sheet的第一行信息。
5:获取每一行的数据–放到sheet第一行以后。
@Test
publicvoidexport()throwsException{
//声明需要导出的数据库
StringdbName="focus";
//声明book
HSSFWorkbookbook=newHSSFWorkbook();
//获取Connection,获取db的元数据
Connectioncon=DataSourceUtils.getConn();
//声明statemen
Statementst=con.createStatement();
//st.execute("use"+dbName);
DatabaseMetaDatadmd=con.getMetaData();
//获取数据库有多少表
ResultSetrs=dmd.getTables(dbName,dbName,null,newString[]{"TABLE"});
//获取所有表名-就是一个sheet
List<String>tables=newArrayList<String>();
while(rs.next()){
StringtableName=rs.getString("TABLE_NAME");
tables.add(tableName);
}
for(StringtableName:tables){
HSSFSheetsheet=book.createSheet(tableName);
//声明sql
Stringsql="select*from"+dbName+"."+tableName;
//查询数据
rs=st.executeQuery(sql);
//根据查询的结果,分析结果集的元数据
ResultSetMetaDatarsmd=rs.getMetaData();
//获取这个查询有多少行
intcols=rsmd.getColumnCount();
//获取所有列名
//创建第一行
HSSFRowrow=sheet.createRow(0);
for(inti=0;i<cols;i++){
StringcolName=rsmd.getColumnName(i+1);
//创建一个新的列
HSSFCellcell=row.createCell(i);
//写入列名
cell.setCellValue(colName);
}
//遍历数据
intindex=1;
while(rs.next()){
row=sheet.createRow(index++);
//声明列
for(inti=0;i<cols;i++){
Stringval=rs.getString(i+1);
//声明列
HSSFCellcel=row.createCell(i);
//放数据
cel.setCellValue(val);
}
}
}
con.close();
book.write(newFileOutputStream("d:/a/"+dbName+".xls"));
}
以上就是本文的全部内容,希望对大家的学习有所帮助。