Chinaunix首页 | 论坛 | 博客
  • 博客访问: 981006
  • 博文数量: 152
  • 博客积分: 4937
  • 博客等级: 上校
  • 技术积分: 1662
  • 用 户 组: 普通用户
  • 注册时间: 2007-10-05 16:55
文章分类

全部博文(152)

文章存档

2013年(12)

2012年(6)

2011年(58)

2010年(43)

2009年(1)

2008年(15)

2007年(17)

我的朋友

分类:

2009-01-06 17:19:55

Tomcat的数据库连接池是使用Jakarta-Commons项目中Database Connection Pool,包含下列组件:
Jakarta-Commons DBCP 、Jakarta-Commons Collections和Jakarta-Commons Pool。
这些库文件包必须和JDBC驱动程序一起安装在$CATALINA_HOME/common/lib这个目录下。
如果检查发现没有,请到中下载相应的库文件包。

在$CATALINA_HOME/common/lib必须有下列包:
commons-collections.jar
commons-dbcp.jar
commons-pool.jar

数据库驱动:
mysql-connector-java-3.0.7-stable-bin.jar //MySQL的驱动程序。


 auth="Container"
 type="javax.sql.DataSource"
        maxActive="100"
 maxIdle="30"
 maxWait="10000"
        username="sa"
 password="sa"
 driverClassName="oracle.jdbc.driver.OracleDriver"
        url="jdbc:oracle:thin:@ip:端口:sid"/>
 
 
 
 
 
  
  
     
 
 
更改web.xml如下:

Simple Register

DB Connection
jdbc/userDB
javax.sql.DataSource
Container


这样在Web容器中,通过java:comp/env/jdbc/userDB就可以寻找到jdbc/userDB的连接池。注意,在Java代码中写JNDI Name时,要加上java:comp/env/,这也是通用规定。 

 

 

/*****用连接池获得连接的代码***********/
public Connection getDBConnect(){
  // TODO 自动生成方法存根
  Connection conn=null;
  try{
   Context initCtx = new InitialContext();
   Context ctx = (Context) initCtx.lookup("java:/comp/env");
   DataSource ds = (DataSource) ctx.lookup("jdbc/book");
   
   conn = ds.getConnection();
   if(conn != null){
    System.out.println("获得连接");
   }else{
    System.out.println("没有获得连接");
   }
  }catch(Exception ex){
   ex.printStackTrace();
  }
  return conn;
 }

//下面是JSP获取连接的测试代码
<%
   Connection conn = null;
   DBConnect db = new DBConnect();
   try{
     conn = db.getDBConnect();
     if(conn != null){
      out.println("获得连接");
     }else{
      out.println("无连接"); 
     }
     out.println("
");
   }catch(Exception ex){
     out.println(ex.getMessage());
   }finally{
     try{
      if(conn != null){
       conn.close();
       conn = null;
      }
     }catch(Exception ex){
      //不处理异常
     }
   }  

    %>

 

编写jsp测试代码

在应用的目录下建立一个Test.jsp文件,代码如下:
"">
<%@ page import="java.sql.*"%>
<%@ page import="javax.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page session="false" %>




<%
out.print("我的测试开始");
DataSource ds = null;
try{
InitialContext ctx=new InitialContext();
ds=(DataSource)ctx.lookup("java:comp/env/jdbc/mysql");
Connection conn = ds.getConnection();
Statement stmt = conn.createStatement();
//提示:users必须是数据库已有的表,
//这里的数据库前文提及的Data Source URL配置里包含的数据库。
String strSql = " select * from users";
ResultSet rs = stmt.executeQuery(strSql);
while(rs.next()){
out.print(rs.getString(1));
}
out.print("我的测试结束");
}
catch(Exception ex){
out.print(“出现例外,信息是:”+ex.getMessage());
ex.printStackTrace();
}
%>




阅读(901) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~