/** * */ 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; } } }
jndi连接Oracle性能怎么样,JNDI连接Oracle
最新推荐文章于 2023-03-08 16:02:39 发布