【发布时间】:2015-07-15 14:41:07
【问题描述】:
我的 WebLogic Server 上有两个数据源,每个都访问不同的数据库。
在我的客户端应用程序上,我有一些方法需要先连接到 DB,以及其他需要连接到 second 的。
但是当我运行它时,它只会获得我执行的第一个方法的连接。
例如,如果我执行一个获取第一个 DB 连接的方法,只有访问该 DB 的方法才能工作,我无法执行任何需要另一个连接的方法。
有人可以帮我吗?我正在使用 WebLogic 12c
这是我获取数据源的类:
package com.henrique.dao;
import java.sql.Connection;
import javax.naming.*;
import javax.sql.*;
public class KironMySql {
private static DataSource KironMySql = null;
private static Context context = null;
public static DataSource KironMySqlConn() throws Exception{
if (KironMySql != null) {
return KironMySql;
}
try{
if(KironMySql == null){
context = new InitialContext();
KironMySql = (DataSource) context.lookup("KironLocal");
}
}catch(Exception e){
e.getMessage();
}
return KironMySql;
}
public static DataSource KironMySqlConnIp() throws Exception{
if (KironMySql != null) {
return KironMySql;
}
try{
if(KironMySql == null){
context = new InitialContext();
KironMySql = (DataSource) context.lookup("KironTabelaApp");
}
}catch(Exception e){
e.getMessage();
}
return KironMySql;
}
public static Connection KironConnection(){
Connection conn = null;
try{
conn = KironMySqlConn().getConnection();
return conn;
}catch(Exception e){
e.getMessage();
}
return conn;
}
public static Connection KironConnectionIp(){
Connection conn = null;
try{
conn = KironMySqlConnIp().getConnection();
return conn;
}catch(Exception e){
e.getMessage();
}
return conn;
}
}
这里有两个使用不同连接的方法示例:
public JSONArray Login(String usu_login, String usu_senha) throws Exception{
PreparedStatement query = null;
Connection conn = null;
ToJson converter = new ToJson();
JSONArray json = new JSONArray();
try{
conn = KironMySql.KironConnection();
query = conn.prepareStatement("select usu_nome from usuario where usu_login = ? and usu_senha = ?");
query.setString(1, usu_login);
query.setString(2, usu_senha);
ResultSet rs = query.executeQuery();
json = converter.toJSONArray(rs);
query.close();
}catch(Exception e){
e.printStackTrace();
return json;
}finally{
if(conn != null) conn.close();
}
return json;
}
public JSONArray getIp(String emp_codigo) throws Exception{
PreparedStatement query = null;
Connection conn = null;
ToJson converter = new ToJson();
JSONArray json = new JSONArray();
try{
conn = KironMySql.KironConnectionIp();
query = conn.prepareStatement("select con_ip from conexaoapp where emp_codigo = ?");
query.setString(1, emp_codigo);
ResultSet rs = query.executeQuery();
json = converter.toJSONArray(rs);
query.close();
}catch(Exception e){
e.printStackTrace();
return json;
}finally{
if(conn != null) conn.close();
}
return json;
}
【问题讨论】:
-
您是否从 WL 的“监控”选项卡中验证了您的两个数据源都处于“运行”状态??
-
@hagrawal 只有一个连接在运行。如何将两个连接都更改为运行状态
-
但是 WL 中的 "KironLocal" 和 "KironTabelaApp" DS 是不是都在运行??
-
如果你想与不同的数据库建立不同的连接,那么你需要为每个数据库有不同的数据源。并从应用程序中获取与每个 DS 的连接(即与数据库的连接),并使用它。不要使用同一个连接来连接 2 个不同的 DS(即与数据库的连接)
标签: java web connection database-connection weblogic12c