java導(dǎo)出數(shù)據(jù)庫(kù)的全部表到excel
本文實(shí)例為大家分享了java將某個(gè)數(shù)據(jù)庫(kù)的表全部導(dǎo)出到excel中的方法,供大家參考,具體內(nèi)容如下
第一步:如何用POI操作Excel
@Test public void createXls() throws Exception{ //聲明一個(gè)工作薄 HSSFWorkbook wb = new HSSFWorkbook(); //聲明表 HSSFSheet sheet = wb.createSheet("第一個(gè)表"); //聲明行 HSSFRow row = sheet.createRow(7); //聲明列 HSSFCell cel = row.createCell(3); //寫入數(shù)據(jù) cel.setCellValue("你也好"); FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls"); wb.write(fileOut); fileOut.close(); }
第二步:導(dǎo)出指定數(shù)據(jù)庫(kù)的所有表
分析:
1:某個(gè)數(shù)數(shù)據(jù)庫(kù)有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table}); - excel的文件名稱。
2:對(duì)每一個(gè)表進(jìn)行select * 操作?!。∶恳粋€(gè)sheet的名稱。
3:分析表結(jié)構(gòu),rs.getMetadate(); ResultSetMedated
4:多個(gè)列,列名是什么. ?。∽侄蚊褪莝heet的第一行信息。
5:獲取每一行的數(shù)據(jù) – 放到sheet第一行以后。
@Test public void export() throws Exception{ //聲明需要導(dǎo)出的數(shù)據(jù)庫(kù) String dbName = "focus"; //聲明book HSSFWorkbook book = new HSSFWorkbook(); //獲取Connection,獲取db的元數(shù)據(jù) Connection con = DataSourceUtils.getConn(); //聲明statemen Statement st = con.createStatement(); //st.execute("use "+dbName); DatabaseMetaData dmd = con.getMetaData(); //獲取數(shù)據(jù)庫(kù)有多少表 ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"}); //獲取所有表名?。【褪且粋€(gè)sheet List<String> tables = new ArrayList<String>(); while(rs.next()){ String tableName = rs.getString("TABLE_NAME"); tables.add(tableName); } for(String tableName:tables){ HSSFSheet sheet = book.createSheet(tableName); //聲明sql String sql = "select * from "+dbName+"."+tableName; //查詢數(shù)據(jù) rs = st.executeQuery(sql); //根據(jù)查詢的結(jié)果,分析結(jié)果集的元數(shù)據(jù) ResultSetMetaData rsmd = rs.getMetaData(); //獲取這個(gè)查詢有多少行 int cols = rsmd.getColumnCount(); //獲取所有列名 //創(chuàng)建第一行 HSSFRow row = sheet.createRow(0); for(int i=0;i<cols;i++){ String colName = rsmd.getColumnName(i+1); //創(chuàng)建一個(gè)新的列 HSSFCell cell = row.createCell(i); //寫入列名 cell.setCellValue(colName); } //遍歷數(shù)據(jù) int index = 1; while(rs.next()){ row = sheet.createRow(index++); //聲明列 for(int i=0;i<cols;i++){ String val = rs.getString(i+1); //聲明列 HSSFCell cel = row.createCell(i); //放數(shù)據(jù) cel.setCellValue(val); } } } con.close(); book.write(new FileOutputStream("d:/a/"+dbName+".xls")); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- Java實(shí)現(xiàn)從數(shù)據(jù)庫(kù)導(dǎo)出大量數(shù)據(jù)記錄并保存到文件的方法
- Java數(shù)據(jù)導(dǎo)出功能之導(dǎo)出Excel文件實(shí)例
- Java實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)的方法示例
- Java使用poi組件導(dǎo)出Excel格式數(shù)據(jù)
- Java使用easyExcel導(dǎo)出excel數(shù)據(jù)案例
- java從mysql導(dǎo)出數(shù)據(jù)的具體實(shí)例
- java web將數(shù)據(jù)導(dǎo)出為pdf格式文件代碼片段
- java實(shí)現(xiàn)異步導(dǎo)出數(shù)據(jù)
- Java樹(shù)形結(jié)構(gòu)數(shù)據(jù)生成導(dǎo)出excel文件方法記錄
- JAVA實(shí)現(xiàn)億級(jí)千萬(wàn)級(jí)數(shù)據(jù)順序?qū)С龅氖纠a
相關(guān)文章
解決redisTemplate向redis中插入String類型數(shù)據(jù)時(shí)出現(xiàn)亂碼問(wèn)題
這篇文章主要介紹了解決redisTemplate向redis中插入String類型數(shù)據(jù)時(shí)出現(xiàn)亂碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Java源碼解析CopyOnWriteArrayList的講解
今天小編就為大家分享一篇關(guān)于Java源碼解析CopyOnWriteArrayList的講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01SpringBoot一個(gè)非常蛋疼的無(wú)法啟動(dòng)的問(wèn)題解決
這篇文章主要介紹了SpringBoot一個(gè)非常蛋疼的無(wú)法啟動(dòng)的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11解析Java編程中設(shè)計(jì)模式的開(kāi)閉原則的運(yùn)用
這篇文章主要介紹了解析Java編程中設(shè)計(jì)模式的開(kāi)閉原則的運(yùn)用,開(kāi)閉原則多應(yīng)用于Java程序的擴(kuò)展開(kāi)發(fā)方面,需要的朋友可以參考下2016-02-02基于java SSM springboot實(shí)現(xiàn)抗疫物質(zhì)信息管理系統(tǒng)
這篇文章主要介紹了基于JAVA SSM springboot實(shí)現(xiàn)的抗疫物質(zhì)信息管理系統(tǒng),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08javaBean的基礎(chǔ)知識(shí)及常見(jiàn)亂碼解決方法
這篇文章主要介紹了javaBean的基礎(chǔ)知識(shí)及常見(jiàn)亂碼解決方法的相關(guān)資料,需要的朋友可以參考下2017-03-03