如何用java将数据库中的表导出到excel

如何用java将数据库中的表导出到excel,第1张

第一步:如何用POI *** 作Excel

@Test

public void createXls() throws Exception{

//声明一个工作薄

HSSFWorkbook wb = new HSSFWorkbook()

//声明表

HSSFSheet sheet = wb.createSheet("第一个表")

//声明行

HSSFRow row = sheet.createRow(7)

//声明列

HSSFCell cel = row.createCell(3)

//写入数据

cel.setCellValue("你也好")

FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls")

wb.write(fileOut)

fileOut.close()

}

第二步:导出指定数据库的所有表

分析:

1:某个数数据库有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table}) - excel的文件名称。

2:对每一个表进行select * *** 作。 - 每一个sheet的名称。

3:分析表结构,rs.getMetadate()ResultSetMedated

4:多个列,列名是什么.- 字段名就是sheet的第一行信息。

5:获取每一行的数据 – 放到sheet第一行以后。

@Test

public void export() throws Exception{

//声明需要导出的数据库

String dbName = "focus"

//声明book

HSSFWorkbook book = new HSSFWorkbook()

//获取Connection,获取db的元数据

Connection con = DataSourceUtils.getConn()

//声明statemen

Statement st = con.createStatement()

//st.execute("use "+dbName)

DatabaseMetaData dmd = con.getMetaData()

//获取数据库有多少表

ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"})

//获取所有表名 - 就是一个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

//查询数据

rs = st.executeQuery(sql)

//根据查询的结果,分析结果集的元数据

ResultSetMetaData rsmd = rs.getMetaData()

//获取这个查询有多少行

int cols = rsmd.getColumnCount()

//获取所有列名

//创建第一行

HSSFRow row = sheet.createRow(0)

for(int i=0i<colsi++){

String colName = rsmd.getColumnName(i+1)

//创建一个新的列

HSSFCell cell = row.createCell(i)

//写入列名

cell.setCellValue(colName)

}

//遍历数据

int index = 1

while(rs.next()){

row = sheet.createRow(index++)

//声明列

for(int i=0i<colsi++){

String val = rs.getString(i+1)

//声明列

HSSFCell cel = row.createCell(i)

//放数据

cel.setCellValue(val)

}

}

}

con.close()

book.write(new FileOutputStream("d:/a/"+dbName+".xls"))

}

MySql导出数据库的命令如下:

Sql代码

mysqldump -uusername -ppassword -hhost -Pport exportDatabaseName >exportPath

mysqldump -uusername -ppassword -hhost -Pport exportDatabaseName >exportPath

利用Java调用命令窗口执行命令来进行MySql导入数据库一般分三步走:

第一步:登录Mysql数据库,在登录数据库的时候也可以指定登录到哪个数据库,如果指定了则可以跳过第二步;

第二步:切换数据库到需要导入的目标数据库

第三步:利用命令开始导入

在进行导出的时候,需要注意命令语句的运行环境,如果已经将mysql安装路径下的bin加入到

系统的path变量中,那么在导出的时候可以直接使用命令语句,否则,就需要在执行命令语句的

时候加上命令所在位置的路径,即mysql安装路径想的bin下的mysqldump命令。

首先导入 mysql-connector-java-5.1.45-bin.jar 包

代码如下:

import java.io.*

import java.sql.*

public class App {

    public static void main(String[] args) {

        

        try {

            

            Class.forName("com.mysql.jdbc.Driver")

            

            // 数据库用户

            String user = "root"

            

            // 数据库密码

            String password = ""

            

            Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db_sale", user, password)

            

            Statement stmt = conn.createStatement()

            

            // 查询 , 从数据库 db_sale 的 product 表中查询 id, name, qty 字段

            ResultSet rs = stmt.executeQuery("SELECT id, name, qty FROM product")

            

            // 创建输出文件 result.txt

            File file = new File("d://result.txt")

            OutputStreamWriter writer = new OutputStreamWriter(new FileOutputStream(file))

            

            while (rs.next()) {

                

                writer.write(String.valueOf(rs.getLong(1)) + "\t")

                writer.write(rs.getString(2) + "\t")

                writer.write(String.valueOf(rs.getInt(3)))

                writer.write("\r\n")

                

                //System.out.println(rs.getLong(1))

                //System.out.println(rs.getString(2))

                //System.out.println(rs.getLong(3))

            }

            

            writer.flush()

            writer.close()

            

            rs.close()

            stmt.close()

            conn.close()

            

        } catch (Exception e) {

            e.printStackTrace()

        }

    }

}


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存