jdbc获取mysql、oracle数据库的表、字段、主键、唯一索引

本文介绍了如何通过jdbc连接mysql和oracle数据库,获取库中的所有表,以及针对特定表获取其字段、主键和唯一索引信息。特别指出在oracle中由于区分大小写,获取唯一索引时需要注意。
摘要由CSDN通过智能技术生成

根据数据库的四大参数获取指定库中的所有表

//根据数据库的参数获取指定库中的所有表
 public static List<Map<String, String>> getDbTables(String driver, String url, String user, String pwd) {
        Connection conn = null;
        ResultSet rs = null;
        List<Map<String, String>> tables = new ArrayList<>();
        try {
            conn = getConnections(driver, url, user, pwd);
            DatabaseMetaData dbMetaData = conn.getMetaData();
            rs = dbMetaData.getTables(null, getSchema(conn), null, new String[]{"TABLE"});
            while (rs.next()) {
                Map<String, String> map = new HashMap<>(1 << 3);
                //获取数据库的表名
                map.put("tableNam", rs.getString("TABLE_NAME"));
                //获取数据库的表类型
                map.put("tableType", rs.getString("TABLE_TYPE"));
                // 所属数据库
                map.put("tableCat", rs.getString("TABLE_CAT"));
                // 所属用户
                map.put("tableSchem", rs.getString("TABLE_SCHEM"));
                map.put("tableRemarks", rs.getString("REMARKS"));

                tables.add(map);
            }
        } catch (Exception e) {
            LoggerUtil.error(String.valueOf(RetCode.DB_CONN_ERROR), Utils.getSt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值