Spring多数据库链接

项目中需要连接多种不同的数据库,下面是实现方法的代码。目前也在找更合适的,能够实现多数据库保持连接。   
public JSONArray getDualByJdbc(Database database, String sql) throws ClassNotFoundException, SQLException {
        //声明Connection对象
        Connection con;
        String driver = "";
        String url = "jdbc:";
        //驱动程序名
        //URL指向要访问的数据库名
        if ("oracle".equals(database.getType())) {
            driver = "oracle.jdbc.OracleDriver";
            url += "oracle:thin:@//" + database.getIp() + ":1521/orcl";
        } else if ("sqlserver".equals(database.getType())) {
            driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
            url += "sqlserver://" + database.getIp() + ":" + database.getPort() + ";DatabaseName=" + database.getName();
        }
        //数据库用户名  username
        String username = database.getUsername();
        //数据库密码    password
        String password = database.getPassword();
        //遍历查询结果集
        //加载驱动程序
        Class.forName(driver);
        //1、连接数据库
        con = DriverManager.getConnection(url, username, password);
        if (!con.isClosed()) {
            //2、创建statement类对象,用来执行sql语句
            Statement statement = con.createStatement();
            //3、ResultSet类,用来存放获取的结果集
            JSONArray array = new JSONArray();
            ResultSet rs = statement.executeQuery(sql);
            ResultSetMetaData metaData = rs.getMetaData();
            int columnCount = metaData.getColumnCount();
            while (rs.next()) {
                JSONObject json = new JSONObject();
                for (int i = 1; i <= columnCount; i++) {
                    String columnName = metaData.getColumnLabel(i);
                    String value = rs.getString(columnName);
                    json.put(columnName, value);
                }
                array.add(json);
            }
            rs.close();
            con.close();
            return array;
        }
        return null;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值