jndi连接Oracle性能怎么样,JNDI连接Oracle

/**  *   */ package tree; import java.sql.Connection; import java.sql.Statement; import javax.naming.Context; import javax.naming.InitialContext; import javax.sql.DataSource; /**  * @author RenCong  * @email rencongwhu@foxmail.com  * @org edu.whu.cs  * @date 2014-9-10  */ public class OracleConnection { private Connection connection = null; private Statement statement = null; @SuppressWarnings("finally") public Statement getStatement() {// ������ݿⷽ��s try  { if(connection == null) { connection = getConnection(); } statement = connection.createStatement(); } catch (Exception e) { e.printStackTrace(); } finally { return statement; } } //JNDI   /** * 获得初始化的JNDI环境,调用lookup方法获得DataSource对象 * JNDI服务者把DataSource对象返回给Java应用程序 * 应用程序调用DataSource 的getConnection方法 * 调用getConnection方法时,在连接缓冲池中查找PooledConnection对象,该对象建立物理连接 * 如果找到PooledConnection对象,则把换冲刺中的对象返回给应用程序并建立物理连接 * 如果没有找到PooledConnection对象,则通过ConnectionPoolDataSource来创建PooledConnection对象 * PooledConnection对象调用getConnection方法,驱动程序创建java.sql.Connection对象并返回 * 该JDBC Connection用于应用程序和数据库引擎的交互 * 如果不再使用数据库连接,可以调用close方法来关闭连接,但是缓冲池的资源并没有释放 *  * @return */ /** name 表示指定的jndi名称 auth 表示认证方式,一般为Container type 表示数据源床型,使用标准的javax.sql.DataSource maxActive 表示连接池当中最大的数据库连接 maxIdle 表示最大的空闲连接数 maxWait 当池的数据库连接已经被占用的时候,最大等待时间 logAbandoned 表示被丢弃的数据库连接是否做记录,以便跟踪 username 表示数据库用户名 password 表示数据库用户的密码 driverClassName 表示JDBC DRIVER url 表示数据库URL地址 */ @SuppressWarnings("finally") public Connection getConnection(){ try { DataSource ds = null; Context initCtx = new InitialContext();    Context envCtx = (Context) initCtx.lookup("java:comp/env");    ds = (DataSource)envCtx.lookup("jdbc/myoracle");    if(ds != null)    {     connection = ds.getConnection();    } } catch (Exception e) { e.printStackTrace(); } finally { return connection;  } } }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值