jsp 数据连接池 2

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 引用:http://bbs.hh010.com/thread-32010-2-1.html //下面这两个是连接池,下面两个文件都放在一个mybean的包里.   package mybean;   import java.

 引用:http://bbs.hh010.com/thread-32010-2-1.html

//下面这两个是连接池,下面两个文件都放在一个mybean的包里.
  package mybean;
  import java.sql.*;
  import java.util.*;
  public class DBConnPool {
  //正在使用连接的数量
  private int using;
  //目前可用的连接数,即空闲连接
  private Vector connections=new Vector();
  //最大连接数
  private int maxconn;
  //连接池名
  private String poolname;
  //数据库标识
  private String dbid;
  //驱动程序名
  private String drivername;
  //数据库帐号
  private String username;
  //数据库密码
  private String passwd;
  public DBConnPool(String poolname,String dbid,String drivername,
  String username,String passwd,int maxconn){
  this.poolname=poolname;
  this.drivername=drivername;
  this.dbid =dbid;
  this.username =username;
  this.passwd=passwd;
  this.maxconn=maxconn;
  }
  /*将空闲连接返回给连接池*/
  public synchronized void returnConnection(Connection conn){
  //将指定连接加到向量末尾
  connections.addElement(conn);
  //连接用户减一
  using--;
  }
  /*从连接池得到一个连接*/
  public synchronized Connection getConnection(){
  Connection conn = null; //Connection是一个类,
  //connections是一个向量,用于存储连接对象,它所存储是的所有空闲状态的可用连接
  if (connections.size() > 0) {
  //获取连接列表的第一个连接
  conn = (Connection) connections.elementAt(0);
  connections.removeElementAt(0);//获得一个连接,并将此连接从队列中删除.
  //如果此连接已关闭,刚继续获取,
  try {
  if (conn.isClosed())
  conn = getConnection();
  }
  catch (Exception e) {
  e.printStackTrace();
  }
  }
  //如果实际使用的连接数小于最大连接数即有可用连接),就新增加一个连接
  else if (maxconn == 0 || using < maxconn){
  //如此时无可用连接(maxconn == 0)且连接数又未达到上限(using < maxconn)),就创建一个新连接
  conn=newConnection();
  }
  //如果连接数已达到上限就返回空指针
  if (conn!=null){
  using++;
  }
  return conn;
  }

/*创建新的连接*/
  public Connection newConnection(){
  Connection conn=null;
  try{
  //加载驱动
  Class.forName(drivername);
  conn=DriverManager.getConnection(dbid,username,passwd);
  }catch(Exception e){
  e.printStackTrace();
  return null;
  }
  return conn;
  }
  /*关闭所有连接*/
  public synchronized void closeConn(){
  Enumeration allConnections=connections.elements();
  while (allConnections.hasMoreElements()){
  Connection conn=(Connection) allConnections.nextElement();
  try{
  conn.close();
  }catch(SQLException e){
  e.printStackTrace();
  }
  }
  connections.removeAllElements();
  }
  }
  package mybean;
  import java.sql.*;
  import java.util.*;
  public class DBConnManager {
  //连接池名列表
  private Vector poolnames =new Vector();
  //驱动程序名列表
  private Vector drivernames=new Vector();
  //数据库标识列表
  private Vector dbids=new Vector();
  //用户名列表
  private Vector usernames=new Vector();
  //用户密码列表
  private Vector passwds=new Vector();
  //最大连接数列表
  private Vector maxconns=new Vector();
  //连接池队列
  private Hashtable connPools=new Hashtable();
  public DBConnManager() {
  //添加Access数据库的连接信息
  poolnames.addElement("access");
  drivernames.addElement("sun.jdbc.odbc.JdbcOdbcDriver");
  dbids.addElement("jdbcdbc:shopping");
  usernames.addElement("");
  passwds.addElement("");
  maxconns.addElement("5");
  //添加SQL Server2000数据库的连接信息
  poolnames.addElement("sqlserver2000");
  drivernames.addElement("com.microsoft.jdbc.sqlserver.SQLServerDriver");
  dbids.addElement("jdbc:microsoft:sqlserver://localhost:1433;DatabserName=shopping");
  usernames.addElement("");
  passwds.addElement("");
  maxconns.addElement("5");

//连接Mysql数据库信息
  poolnames.addElement("mysql");
  drivernames.addElement("org.gjt.mm.mysql.Driver");
  dbids.addElement("jdbc:mysql://localhost/shopping");
  usernames.addElement("");
  passwds.addElement("");
  maxconns.addElement("5");
  //连接Oracle8i/9i数据库
  poolnames.addElement("oracle");
  drivernames.addElement("oracle.jdbc.driver.OracleDriver");
  dbids.addElement("jdbcracle:thinlocalhost:1521:shopping");
  usernames.addElement("");
  passwds.addElement("");
  maxconns.addElement("5");
  //创建连接池
  createPools();
  }
  /*将连接返回给由指定的连接池*/
  public void returnConnection(String name,Connection conn){
  DBConnPool pool=(DBConnPool) connPools.get(name);
  if (pool!=null)
  {
  pool.returnConnection(conn);
  }
  }
  /*得到一个指定连接池中的连接*/
  public Connection getConnection(String name){
  DBConnPool pool=(DBConnPool) connPools.get(name);
  if (pool!=null)
  {
  return pool.getConnection();
  }
  return null;
  }
  /*关闭所有连接*/
  public synchronized void closeConns(){
  Enumeration allPools=connPools.elements();
  while (allPools.hasMoreElements()){
  DBConnPool pool=(DBConnPool) allPools.nextElement();
  pool.closeConn();
  }
  }
  /*创建连接池*/
  private void createPools(){
  for (int i=0;i<poolnames.size();i++)
  {
  String poolname=poolnames.elementAt(i).toString();
  String drivername=drivernames.elementAt(i).toString();
  String dbid=dbids.elementAt(i).toString();
  String username=usernames.elementAt(i).toString();
  String passwd=passwds.elementAt(i).toString();
  int maxconn=0;
  try{
  maxconn=Integer.parseInt(maxconns.elementAt(i).toString());
  }catch (NumberFormatException e){
  e.printStackTrace();
  }
  DBConnPool pool=new DBConnPool(poolname,drivername,dbid,username,
  passwd,maxconn);
  connPools.put(poolname,pool);
  }
  }
  }

下面这个是主页面.JSP文件
  <%@ page contentType="text/html; charset=GBK" %>
  <%@ page import ="java.sql.*" %>
  <jsp:useBean id="connManager" scope="application" class="mybean.DBConnManager" />
  <html>
  <head>
  <title>
  购物商城首页
  </title>
  </head>
  <body bgcolor="#B0C4DE">
  <center><h1>欢迎访问本购物商城</h1></center>
  <%
  //Connection connA=connManager.getConnection("access");
  Connection connS=connManager.getConnection("sqlserver2000");
  if (connS==null)
  {
  %>
  数据库正忙,请稍后再访问
  <%
  }
  //Statement stmtA=connA.createStatement();
  Statement stmtS=connS.createStatement();
  %>
  <%
  String sql="select * from userinfo";
  ResultSet rs=stmtS.executeQuery(sql);
  while (rs.next())
  {
  %>
  <tr>
  <td><%=rs.getString("username")%></td>
  <td><%=rs.getString("userpass")%></td>
  </tr>
  <%
  }
  rs.close();
  stmtS.close();
  connManager.returnConnection("sqlserver2000",connS);
  %>
  </body>
  </html>

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
29天前
|
Java 应用服务中间件
jsp数据交互(一)
jsp数据交互(一)
10 0
|
7月前
|
JavaScript Java
JSP如何调用JS的数据(变量)?
JSP如何调用JS的数据(变量)?
154 0
|
8月前
|
前端开发 Java
前端——HTML或者JSP页面--执行完某事件后刷新页面,重置表单,清空数据
前端——HTML或者JSP页面--执行完某事件后刷新页面,重置表单,清空数据
|
9月前
|
前端开发 Java 关系型数据库
欢迎来到Jsp编程课时十三——分解原理:构建自己的思路,目标更好的理解对数据的增伤改查的原理和过程。
欢迎来到Jsp编程课时十三——分解原理:构建自己的思路,目标更好的理解对数据的增伤改查的原理和过程。
72 0
|
9月前
|
前端开发 Java 数据库
欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。(三)
欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。(三)
79 0
|
9月前
|
前端开发 Java 数据库
欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。(二)
欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。(二)
48 0
|
9月前
|
前端开发 搜索推荐 Java
欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。(一)
欢迎来到Jsp编程课时十二——今天实现的目标是。@1将数据库的数据发送到浏览器。@2利用浏览器实现对数据库的增删改查操作。@3理解MVC三层架构的定义。(一)
64 0
|
Java
JSP 读取表单数据
JSP 读取表单数据
69 0
|
安全 Java
自定义JSP[if,foreach,数据,select]标签
自定义JSP[if,foreach,数据,select]标签
自定义JSP[if,foreach,数据,select]标签
|
Java 容器
JSP数据交互
JSP数据交互
143 0
JSP数据交互