通过Connection连接获取数据库元数据

前一段时间做大数据产品时用到了一部分通过Connection连接获取mysql数据库的元数据,现在把部分代码贴下来,以备不时之需

 

1、通过Connection连接获取数据库中所有的表

@Test
public void test1() throws SQLException {
	Connection conn = //... some exists Connection
	DatabaseMetaData metaData = conn.getMetaData();
    ResultSet itr = metaData.getTables(null, "%","%",new String[]{"TABLE"});
    while(itr.next()){
        String TABLE_CAT = itr.getString("TABLE_CAT");
        String TABLE_SCHEM = itr.getString("TABLE_SCHEM");
        String TABLE_NAME = itr.getString("TABLE_NAME");
        String TABLE_TYPE = itr.getString("TABLE_TYPE");
        String REMARKS = itr.getString("REMARKS");
        System.out.println(TABLE_CAT+" , "+TABLE_SCHEM+" , "+TABLE_NAME+" , "+TABLE_TYPE+"  ,  "+REMARKS+" , ,  ,   ,    ,  ");
    }
}

其中:TABLE_NAME代表表名

 

2、通过Connection连接获取某个表的字段

@Test
public void test2() throws SQLException {
	Connection conn = //... some exists Connection
	DatabaseMetaData metaData = conn.getMetaData();
    ResultSet data_filter = metaData.getColumns(conn.getCatalog(),"%","lyh_test_data",null);
    while(data_filter.next()){
        int one = data_filter.getInt("DATA_TYPE");
        int two = data_filter.getInt("COLUMN_SIZE");
        String three = data_filter.getString("COLUMN_NAME");
        System.out.println(one+"    "+two+"     "+three);
    }
}

其中: lyzx_test_data是我的测试表名  COLUMN_NAME代表字段名,COLUMN代表字段大小  DATA_TYPE代表字段类型

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值