代码下载:https://files.cnblogs.com/files/xiandedanteng/FindNotnullColumns20191102-2.rar

这篇还不够完善,请看更完善的续篇 https://www.cnblogs.com/xiandedanteng/p/11783796.html

本例主要使用的是JDBC提供的ResultSetMetaData类去取表的相关信息,文中只取了四种,其它信息大家可以查看这个类的方法而得知。

JavaCode:

package com.hy;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.List;

import org.apache.log4j.Logger;

class Field{
    String name;    // 列名
    int size;        // 列容量
    String type;    // 列数据类型
    boolean allowNull;// 列是否允許为空
}

/**
 * 利用ResultSetMetaData从数据库的某表中获取字段信息并存到csv文件
 * @author horn1
 *
 */
public class ColumnSeeker {
    private static Logger log = Logger.getLogger(ColumnSeeker.class);

    private static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
    private static final String DB_URL = "jdbc:mysql://192.168.161.130:3306/test";
    private static final String USER = "root";
    private static final String PSWD = "12345678";

    private List<Field> fields;

    /**
     * 从DB里取字段
     * @param tablename
     * @return
     */
    public List<Field> fetchAllColumns(String tablename){
        fields=new ArrayList<Field>();

        Connection conn = null;
        Statement stmt = null;

        try {
            Class.forName(JDBC_DRIVER).newInstance();
            conn = DriverManager.getConnection(DB_URL, USER, PSWD);
            stmt = conn.createStatement();

            String sql = "select * from emp order by id limit 1";
            ResultSet rs = stmt.executeQuery(sql);
            ResultSetMetaData rsMetadata = rs.getMetaData();

            while (rs.next()) {
                int count = rsMetadata.getColumnCount();
                for (int i=1; i<count+1; i++) {
                    // 列名
                    String columnName = rsMetadata.getColumnLabel(i);
                    // 列容量
                    int size =rsMetadata.getColumnDisplaySize(i);
                    // 列数据类型
                    String columnType = rsMetadata.getColumnTypeName(i);
                    // 列是否允許为空
                    boolean allowNull=(rsMetadata.isNullable(i)!=0);

                    /*String raw = "columnName={0},size={1},columnType={2},allowNull={3}";
                    Object[] arr = { columnName, size, columnType,allowNull};
                    String outStr = MessageFormat.format(raw, arr);
                    log.info(outStr);*/

                    Field f=new Field();
                    f.name=columnName;
                    f.size=size;
                    f.type=columnType;
                    f.allowNull=allowNull;
                    fields.add(f);
                }
            }

            rs.close();
        } catch (Exception e) {
            System.out.print("DB/SQL ERROR:" + e.getMessage());
        } finally {
            try {
                stmt.close();
                conn.close();
            } catch (SQLException e) {
                System.out.print("Can't close stmt/conn because of " + e.getMessage());
            }
        }

        return fields;
    }

    /**
     * 打印全部字段
     */
    public void printFields() {
        for(Field f:fields) {
            String raw = "column name={0},size={1},type={2},allowNull={3}";
            Object[] arr = { f.name, f.size, f.type,f.allowNull};
            String outStr = MessageFormat.format(raw, arr);
            //log.info(outStr);
        }
    }

    /**
     * 输出全部列到csv文件
     * @param csvFilename
     * @return
     */
    public boolean saveAllToCsv(String csvFilename) {
        try {
            FileWriter fileWriter = new FileWriter(new File(csvFilename), true);

            List<String> allowNulls=new ArrayList<String>();
            List<String> allowType=new ArrayList<String>();
            List<String> allowSize=new ArrayList<String>();
            List<String> allowName=new ArrayList<String>();

            for(Field f:fields) {
                allowNulls.add(String.valueOf(f.allowNull));
                allowType.add(f.type);
                allowSize.add(String.valueOf(f.size));
                allowName.add(f.name);
            }

            String line="";

            line =String.join(",", allowSize)+ System.getProperty("line.separator");
            fileWriter.write(line);

            line =String.join(",", allowType)+ System.getProperty("line.separator");
            fileWriter.write(line);

            line =String.join(",", allowNulls)+ System.getProperty("line.separator");
            fileWriter.write(line);

            line =String.join(",", allowName)+ System.getProperty("line.separator");
            fileWriter.write(line);

            fileWriter.flush();
            fileWriter.close();

            return true;
        } catch (IOException e) {
            e.printStackTrace();
        }

        return false;
    }

    /**
     * 仅将非空列输出到CSV
     * @param csvFilename
     * @return
     */
    public boolean saveNotnullToCsv(String csvFilename) {
        try {
            FileWriter fileWriter = new FileWriter(new File(csvFilename), true);

            List<String> allowNulls=new ArrayList<String>();
            List<String> allowType=new ArrayList<String>();
            List<String> allowSize=new ArrayList<String>();
            List<String> allowName=new ArrayList<String>();

            for(Field f:fields) {
                if(f.allowNull==false) {
                    allowNulls.add(String.valueOf(f.allowNull));
                    allowType.add(f.type);
                    allowSize.add(String.valueOf(f.size));
                    allowName.add(f.name);
                }
            }

            String line="";

            line =String.join(",", allowSize)+ System.getProperty("line.separator");
            fileWriter.write(line);

            line =String.join(",", allowType)+ System.getProperty("line.separator");
            fileWriter.write(line);

            line =String.join(",", allowNulls)+ System.getProperty("line.separator");
            fileWriter.write(line);

            line =String.join(",", allowName)+ System.getProperty("line.separator");
            fileWriter.write(line);

            fileWriter.flush();
            fileWriter.close();

            return true;
        } catch (IOException e) {
            e.printStackTrace();
        }

        return false;
    }

    public static void main(String[] args) {
        ColumnSeeker cs=new ColumnSeeker();
        cs.fetchAllColumns("emp");
        cs.printFields();
        cs.saveAllToCsv("d:\\all.csv");
        cs.saveNotnullToCsv("d:\\notnulls.csv");

        log.info("Completed");
    }
}

输出的CSV文件截图:

--END-- 2019年11月2日11:05:53

【Java/JDBC】利用ResultSetMetaData从数据库的某表中获取字段信息并存到csv文件的更多相关文章

  1. 【Java/JDBC】借助ResultSetMetaData,从数据库表中抽取字段信息存成Excel文件

    本例工程下载:https://files.cnblogs.com/files/xiandedanteng/FindNotnullColumns20191102-3.rar 工作中曾有个为42张表建立测 ...

  2. c++获取sqlite3数据库表中所有字段的方法

    常用方法: 1.使用sqlite3_get_table函数 2.获取sqlite创建表的sql语句字符串,然后进行解析获取到相应的字段 3.采用配置文件的方式,将所有字段名写入配置文件 方法1:使用s ...

  3. Mysql 导出数据库和指定表中的数据

    参考地址:http://jingyan.baidu.com/article/b7001fe14240ab0e7282dde9.html [root@youo zw]# mysqldump -u roo ...

  4. 数据库小记:根据指定名称查询数据库表名及根据指定名称查询数据库所有表中的字段名称(支持mysql/postgre)

    意:本篇文章仅适用于mysql和postgre这两种数据库 1.查询数据库中所有表名及对应表的详细信息 select * from INFORMATION_SCHEMA.tables 2.根据指定名称 ...

  5. 使用pandas中的raad_html函数爬取TOP500超级计算机表格数据并保存到csv文件和mysql数据库中

    参考链接:https://www.makcyun.top/web_scraping_withpython2.html #!/usr/bin/env python # -*- coding: utf-8 ...

  6. SqlServer中获取所有数据库,所有表,所有字段

    原文:SqlServer中获取所有数据库,所有表,所有字段 一.获取所有数据库 select * from master.dbo.SysDatabases 二.获取某个库中所有表 SELECT * F ...

  7. SQL语句的使用,SELECT - 从数据库表中获取数据 UPDATE - 更新数据库表中的数据 DELETE - 从数据库表中删除数据 INSERT INTO - 向数据库表中插入数据

    SQL DML 和 DDL 可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL). SQL (结构化查询语言)是用于执行查询的语法. 但是 SQL 语言也包含用于更新. ...

  8. 使用ABAP(ADBC)和Java(JDBC)连接SAP HANA数据库

    在表DBCON里维护一条记录,指向HANA数据库.con_ENV里填入HANA数据库的主机名和端口号.如vmXXXX:30015 DATA: ls_new TYPE DBCON. ls_new-con ...

  9. 一个利用pojo类从前端页面request中获取参数的小框架~

    写之前不知道Spring已经实现这样的功能,所以傻傻的写了这个东西! 实现原理挺有趣的在此记录一下.从去年十月参加java开发以来自己终于有了点小进步. 好开心. 解决问题(详解):前端form表单提 ...

随机推荐

  1. Java实现 Cookie的生成与读取

    今天学习的时候发现Cookie挺有意思的,就自己网上找点例子,自己敲点代码熟练下,现在就记录下来,分享一下. 什么是cookie?? Cookie 是一小段文本信息,伴随着用户请求和页面在 Web 服 ...

  2. Java入门学习总结_02

    一:注释 注释主要就是用来解释某句或者某段代码使得其他人调试更加方便.特点是在编译代码的时候不会编译注释, 不管发不发生错误.注释主要分为单行注释//(快捷键ctrl+/).多行注释/* */(快捷键 ...

  3. css 布局方式

    布局方式 1 布局:设置元素在网页中的排列方式及显示效果 2 分类: 1 标准流布局(文档流,普通流,静态流) 是默认的布局方式 特点:将元素按照书写顺序及元素类型,从上至下,从左至右排列 2 浮动布 ...

  4. bond模式详解

    目录 bond模式详解 一.什么是bond? 二.为什么使用bond? 三.bond模式配置 1.配置linux bond 2.将bond绑定到ovs上面(可选) 四.bond模式 1.模式0 2.模 ...

  5. 《浏览器工作原理与实践》 <12>栈空间和堆空间:数据是如何存储的?

    对于前端开发者来说,JavaScript 的内存机制是一个不被经常提及的概念 ,因此很容易被忽视.特别是一些非计算机专业的同学,对内存机制可能没有非常清晰的认识,甚至有些同学根本就不知道 JavaSc ...

  6. [Mac][Python][Jupyter Notebook]安装配置和使用

    Jupyter 项目(以前称为 IPython 项目),提供了一套使用功能强大的交互式 shell 进行科学计算的工具,实现了将代码执行与创建实时计算文档相结合. 这些 Notebook 文件可以包含 ...

  7. C 全局变量 本地变量

  8. 2.Vue调试工具vue-devtools的安装步骤和使用

    1.安装步骤: 打开谷歌浏览器设置 -->扩展程序 -->勾选开发者模式 --->加载已解压的扩展程序 --->选择“chrome扩展”文件夹即可:

  9. 测试某网站的SMS验证码

    to=18911121211&sms_type=sms_registration&captcha_num=9JCMw4yN5EjI6ISYoNGdwF2YiwiIw5WNwlmb3xm ...

  10. toolbox 中创建nginx服务器,使用localhost不能访问

    使用toolbox 工具使用docker创建nginx 容器,使用localhost不能访问? 使用docker run --rm -d --name dweb  -p 80:80 nginx 命令执 ...