/**
*
*/
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;
}
}
}
*
*/
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;
}
}
}