第1篇:Mysql数据库表结构导出字段到Excel(一个sheet中)

java 复制代码
package com.xx.util;

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.sql.*;
import java.io.*;

public class DatabaseToExcel {

    public static void main(String[] args) throws Exception {

        // 数据库连接配置
        String url = "jdbc:mysql://localhost:3306";
        String user = "root";
        String password = "root";
        String tableName = "table_name";
        String databases = "database_name";

        // 连接数据库
        Connection conn = DriverManager.getConnection(url, user, password);
        DatabaseMetaData metaData = conn.getMetaData();

        // 获取表字段信息
        /**参数
        catalog
        一个包含目录名称的字符串 。
        架构
        一个包含架构名称模式的字符串 。
        table
        一个包含表名称模式的字符串。
        col
        一个包含列名称模式的字符串。
         */
        ResultSet resultSet = metaData.getColumns(databases, null, null, "%");


        // 创建Excel工作簿和工作表
        Workbook workbook = new XSSFWorkbook();
        Sheet sheet = workbook.createSheet("TableInfo");

        // 写入表头
        Row header = sheet.createRow(0);
        header.createCell(0).setCellValue("Name");
        header.createCell(1).setCellValue("Datatype");
        header.createCell(2).setCellValue("Comment");
        header.createCell(3).setCellValue("Null Option");
        header.createCell(4).setCellValue("Is PK");
        header.createCell(5).setCellValue("Is FK");
        header.createCell(5).setCellValue("tableName");

        int rowNum = 1;
        while (resultSet.next()) {
            // 读取字段名和类型
            String columnName = resultSet.getString("COLUMN_NAME");
            String typeName = resultSet.getString("TYPE_NAME");
            String columnSize = resultSet.getString("COLUMN_SIZE");
            String remarks = resultSet.getString("REMARKS");
            String tableName1 = resultSet.getString("TABLE_NAME");

            // 写入数据到Excel
            Row row = sheet.createRow(rowNum);
            row.createCell(0).setCellValue(columnName);
            row.createCell(1).setCellValue(typeName + "(" + columnSize + ")");
            row.createCell(2).setCellValue(remarks);
            row.createCell(3).setCellValue("NULL");
            row.createCell(4).setCellValue("NO");
            row.createCell(5).setCellValue("NO");
            row.createCell(5).setCellValue(tableName1);

            rowNum++;
        }

        // 关闭连接
        resultSet.close();
        conn.close();

        // 写入Excel文件
        FileOutputStream out = new FileOutputStream("TableInfo.xlsx");
        workbook.write(out);
        out.close();

        System.out.println("Excel文件已生成!");
    }
}

导出Excel样例:

相关推荐
档案宝档案管理2 小时前
档案宝:企业合同档案管理的“安全保险箱”与“效率加速器”
大数据·数据库·人工智能·安全·档案·档案管理
wangjialelele2 小时前
mysql库操作二
数据库·mysql
星释2 小时前
二级等保实战:MySQL安全加固
android·mysql·安全
Chloeis Syntax2 小时前
MySQL初阶学习日记(1)--- 数据库的基本操作
数据库·学习·mysql
workflower3 小时前
FDD(Feature Driven Development)特征驱动开发
大数据·数据库·驱动开发·需求分析·个人开发
韩立学长3 小时前
基于Springboot的旧物公益捐赠管理系统3726v22v(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
苦学编程的谢4 小时前
Redis_4_常见命令(完)+认识数据类型和编码方式
数据库·redis·缓存
小光学长4 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
小光学长4 小时前
基于Vue的地铁综合服务管理系统7949eg04(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js