麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Java > 正文

Java 使用poi把數據庫中數據導入Excel的解決方法

2019-11-26 16:08:45
字體:
來源:轉載
供稿:網友
Java 利用poi把數據庫中數據導入Excel

效果:

image

使用時先把poi包導入工程的path,注意只需要導入poi包即可,下載后有三個jar包

核心代碼:

連接數據庫:DBConnection.java

復制代碼 代碼如下:

package org.xg.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DBConnection {
private final String DBUrl ="jdbc:mysql://localhost:3306/notebook" ;
private final String DBDriver ="com.mysql.jdbc.Driver" ;
private final String username ="root" ;
private final String password ="riskfitfeng" ;
private Connection con ;
public DBConnection()
{
try {
Class.forName(DBDriver) ;
con = DriverManager.getConnection(DBUrl,username,password) ;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public Connection getDB()
{
return con ;
}
public void closeDb(ResultSet rs,PreparedStatement ps)
{
if(rs!=null)
{
try {
rs.close() ;
} catch (SQLException e) {
// TODO Auto-generated catch block


e.printStackTrace();
}
}
if(ps!=null)
{
try {
ps.close() ;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}

導入excel類:MySql2Excel.java

package org.xg.db;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.sql.Connection;
import java.sql.ResultSet;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
public class MySql2Excel {
public MySql2Excel() throws Exception
{
Connection con = null ;
DBConnection db = new DBConnection() ;
con = db.getDB() ;
String sql ="select * from students" ;
ResultSet rs = con.createStatement().executeQuery(sql) ;
// 獲取總列數
int CountColumnNum = rs.getMetaData().getColumnCount() ;
int i =1 ;
// 創建Excel文檔
HSSFWorkbook wb = new HSSFWorkbook() ;
// sheet 對應一個工作頁
HSSFSheet sheet = wb.createSheet("student表中的數據") ;
HSSFRow firstrow = sheet.createRow(0); //下標為0的行開始
HSSFCell[] firstcell = new HSSFCell[CountColumnNum];
String[] names = new String[CountColumnNum];
names[0] ="ID";
names[1] ="學號";
names[2] ="姓名";
names[3] ="性別";
names[4] ="班級";
for(int j= 0 ;j<CountColumnNum; j++){
firstcell[j] = firstrow.createCell((short)j);
firstcell[j].setCellValue(new HSSFRichTextString(names[j]));
}
while(rs.next())
{
// 創建電子表格的一行
HSSFRow row = sheet.createRow(i) ; // 下標為1的行開始
for(int j=0;j<CountColumnNum;j++)
{
// 在一行內循環
HSSFCell cell = row.createCell((short) j) ;
// 設置表格的編碼集,使支持中文
//// 先判斷數據庫中的數據類型
// 將結果集里的值放入電子表格中
cell.setCellValue(new HSSFRichTextString(rs.getString(j+1))) ;
}
i++ ;
}
// 創建文件輸出流,準備輸出電子表格
OutputStream out = new FileOutputStream("E://person.xls") ;
wb.write(out) ;
out.close() ;
System.out.println("數據庫導出成功") ;
rs.close() ;
con.close() ;
}
public static void main(String[] args)
{
try {
@SuppressWarnings("unused")
MySql2Excel excel = new MySql2Excel() ;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}



例如你可以在前端jsp中這樣調用:

<a href="ReportServlet" onclick="return confirm('確認數據導出到E:/下?');">導出數據到Excel</a>

后臺servlet寫上上面的代碼,注意最后需要response.sendRedirect("") 返回前端

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 爱福利视频| 久久久久久久久久久av | 欧美一级高清片在线 | 久章草在线观看 | 一级在线观看 | 日本a∨精品中文字幕在线 狠狠干精品视频 | 91一区二区在线观看 | 国产一级性生活视频 | 欧美日韩免费在线观看视频 | 色交视频 | 国产69精品久久久久久 | 一级毛片电影网 | 国产1区视频 | 免费国产一区 | 91精品福利视频 | 久久久久久久久久久久久国产精品 | 中国av免费在线观看 | 精品久久久久久久久久中出 | a视频在线播放 | 亚洲成人免费视频在线 | 九九热这里只有精品8 | 午夜精品视频免费观看 | 欧美日韩在线免费观看 | 久草欧美 | 国产99久久精品一区二区 | 在线成人免费视频 | 国产乱淫a∨片免费观看 | 91精品国| 欧美精品一区自拍a毛片在线视频 | 中文字幕四区 | 99视频有精品视频高清 | 免费欧美一级视频 | 国产在线观看一区二区三区 | jizzjizzjizzjizz国产| 欧美日韩1区2区3区 黄片毛片一级 | 日韩字幕在线观看 | 黄色免费在线电影 | 国产网站黄 | 成人一级在线 | 深夜免费视频 | 91精品国产92久久久久 |