excel2003(xls)只支持65536條數據,poi3.9提供了海量數據導出,支持07和10版(xlsx)java
import java.io.FileOutputStream; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.streaming.SXSSFWorkbook; /** * @Description: poi實現輸出信息到excel文件 * @author dongye * @date 2016年8月17日 下午3:09:13 */ public class TestMore100 { public static void main(String[] args) throws Exception { TestMore100 tm = new TestMore100(); tm.jdbcex(true); } public void jdbcex(boolean isClose) throws InstantiationException, IllegalAccessException, ClassNotFoundException, SQLException, IOException, InterruptedException { String xlsFile = "d:/test100.xlsx"; // 輸出文件 Workbook wb = new SXSSFWorkbook(100); // 建立excel文件,內存只有100條記錄【關鍵語句】 Sheet sheet = wb.createSheet("個人第一個工做簿"); // 創建新的sheet對象 Row nRow = null; Cell nCell = null; // 使用jdbc連接數據庫 Class.forName("com.mysql.jdbc.Driver").newInstance(); String url = "jdbc:mysql://172.20.10.32:3306/sys?characterEncoding=UTF-8"; String user = "root"; String password = "root"; Connection conn = DriverManager.getConnection(url, user, password); Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); String sql = "select name,age,des from customer limit 1000000"; // 100萬測試數據 ResultSet rs = stmt.executeQuery(sql); long startTime = System.currentTimeMillis(); // 開始時間 System.out.println("strat execute time: " + startTime); // context int rowNo = 0; int colNo = 0; while (rs.next()) { colNo = 0; nRow = sheet.createRow(rowNo++); nCell = nRow.createCell(colNo++); nCell.setCellValue(rs.getString(colNo)); nCell = nRow.createCell(colNo++); nCell.setCellValue(rs.getString(colNo)); if (rowNo % 100 == 0) { System.out.println("row no: " + rowNo); } Thread.sleep(1); // 休息一下,防止對CPU佔用 } long finishedTime = System.currentTimeMillis(); // 處理完成時間 System.out.println("finished execute time: " + (finishedTime - startTime) / 1000 + "m"); FileOutputStream fOut = new FileOutputStream(xlsFile); wb.write(fOut); fOut.flush(); fOut.close(); long stopTime = System.currentTimeMillis(); // 寫文件時間 System.out.println("write xlsx file time: " + (stopTime - startTime) / 1000 + "m"); if (isClose) { this.close(rs, stmt, conn); } } // close resource private void close(ResultSet rs, Statement stmt, Connection conn) throws SQLException { rs.close(); stmt.close(); conn.close(); }