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、付费专栏及课程。

余额充值