CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
IBM Rational 系统开发最佳实践工具包 WebSphere MQ 最佳实践 TOP 15
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  Java >  J2EE / EJB / JMS

关于连接池的疑惑

楼主halfheart(半点心)2006-03-03 11:38:29 在 Java / J2EE / EJB / JMS 提问

我的开发环境是   myeclipse4.1   +   struts1.2   +   tomcat5.0  
   
  连接数据库那块是我是在   struts-config.xml   里配置的,代码如下  
      <data-sources   >  
          <data-source   type="org.apache.commons.dbcp.BasicDataSource">  
              <set-property   property="description"   value="mysql"   />  
              <set-property   property="driverClassName"   value="com.mysql.jdbc.Driver"   />  
              <set-property   property="url"   value="jdbc:mysql://localhost/mydatabase?useUnicode=true&amp;characterEncoding=gb2312&amp;zeroDateTimeBehavior=convertToNull"   />  
              <set-property   property="username"   value="myname"   />  
              <set-property   property="password"   value="1111"   />  
              <set-property   property="minCount"   value="1"   />  
              <set-property   property="maxCount"   value="20"   />  
              <set-property   property="readOnly"   value="false"   />  
              <set-property   property="autoCommit"   value="true"   />  
              <set-property   property="LoginTimeout"   value="10000"   />  
          </data-source>  
      </data-sources>  
   
  能对数据库进行正常增删改查操作了.只是我每次对数据库操作都得建立一个connection,   好像速度挺慢的.  
  看了很多朋友的关于数据库连接池的文章,别人都在   tomcat   里配置的,而我现在不是.  
  请问,用我这种方式,能实现连接池么?   如果能,又该如何做? 问题点数:50、回复次数:2Top

1 楼li_d_s(鄙视那些不懂Java却跑来乱骂的人,.NET没啥了不起)回复于 2006-03-03 12:39:11 得分 50

能对数据库进行正常增删改查操作了.只是我每次对数据库操作都得建立一个connection  
  ==========  
  代码呢?Top

2 楼halfheart(半点心)回复于 2006-03-03 13:05:11 得分 0

public   class   DBPool   {  
  private   DataSource   ds   =   null;  
  private   static   Connection   conn;  
  private   PreparedStatement   pstmt;  
   
  public   DBPool(DataSource   ds){  
  this.ds   =   ds;  
  }  
   
  private   boolean   getConnStatus(){  
  boolean   fConn   =   true;  
  try{  
  if   ((conn   ==   null)   ||   conn.isClosed()){  
  conn   =   ds.getConnection();  
  return   true;  
  }  
  if   (conn   !=   null   &&   !conn.isClosed())   {  
  return   true;  
  }  
  }catch(Exception   ex){  
  return   false;  
  }  
   
  return   fConn;  
  }  
   
  public   boolean   processUpdate(String   strSql,   Vector   vParam){  
  if   (this.ds   ==   null){  
  return   false;  
  }  
   
  boolean   fSuccess   =   false;  
  try{  
  if   (getConnStatus()){  
  // conn   =   ds.getConnection();  
  pstmt   =   conn.prepareStatement(strSql);  
  if   (vParam   !=   null){  
  for   (int   i=0;   i<vParam.size();   i++){  
  pstmt.setObject(i+1,   vParam.get(i));  
  }  
  }  
  pstmt.executeUpdate();  
  fSuccess   =   true;  
  }  
  }catch(Exception   ex){  
  return   fSuccess;  
  }  
   
  return   fSuccess;  
  }  
   
  public   ResultSet   processQuery(String   strSql,   Vector   vParam){  
  if   (this.ds   ==   null){  
  return   null;  
  }  
   
  ResultSet   rs   =   null;  
  try{  
  if   (getConnStatus()){  
  // conn   =   ds.getConnection();  
  pstmt   =   conn.prepareStatement(strSql);  
  if   (vParam   !=   null){  
  for   (int   i=0;   i<vParam.size();   i++){  
  pstmt.setObject(i+1,   vParam.get(i));  
  }  
  }  
  rs   =   pstmt.executeQuery();  
  }  
  }catch(Exception   ex){  
  return   rs;  
  }  
   
  return   rs;  
  }  
   
  }  
  Top

相关问题

  • 关于数据库连接池的疑惑
  • lotus连接oracle的疑惑
  • pb动态连接库疑惑
  • 数据库查询连接的疑惑
  • 关于james中连接mysql的疑惑?
  • 疑惑::ASP连接ACCESS的问题!!!
  • (菜鸟)请帮忙解:连接数据库的疑惑
  • JBDC连接数据库的问题,有个疑惑的地方。
  • 疑惑!
  • 疑惑!

关键词

  • 数据库
  • 连接
  • ds
  • null
  • 连接池
  • conn
  • boolean
  • connection
  • private
  • true

得分解答快速导航

  • 帖主:halfheart
  • li_d_s

相关链接

  • CSDN Java频道
  • Java类图书
  • Java类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo