hibernate在tomcat下的尝试2

Cannot create JDBC driver of class '' for connect URL 'null'
的解决方案:
如果是tomcat5.5,则不能按以下方法配置。
[code]
<Resource name="jdbc/MYDS" auth="Container" type="javax.sql.DataSource"/>
<ResourceParams name="jdbc/chen">
<parameter>
<name>username</name>
<value>root</value>
</parameter>
<parameter>
<name>password</name>
<value></value>
</parameter>
<parameter>
<name>driverClassName</name>
<value>com.mysql.jdbc.Driver</value>
</parameter>
<parameter>
<name>url</name>
<value>jdbc:mysql://localhost/voff</value>
</parameter>
</ResourceParams>
</Context>

[/code]

应该按以下的方式配置。
[code]

<Resource
name="jdbc/chen"
auth="Container"
type="javax.sql.DataSource"
username="root"
password=""
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/voff"
/>
[/code]

存为Context.xml放在META-INF下即可。
测试代码:
[code]
<%@ page language="java" contentType="text/html;charset=GB2312"%>
<%@ page import="java.sql.*,javax.sql.*,javax.naming.*"%>
<%
Connection conn=null;
String url="jdbc:mysql://localhost:3306/voff";
String user="root";
String password="";
try{
InitialContext ctx=new InitialContext();
DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/chen");
conn=ds.getConnection();
if(conn!=null)
{
out.println("数据源jdbc/chen配置正确!");
}
}catch(Exception e)
{
out.println("数据库驱动加载出现错误!"+e.getMessage());
}
%>[/code]

一个测试JNDI的驱动测试:
[code]
<%@page contentType="text/html;charset=gb2312"%>
<%@page import="java.sql.*"%>
<%@page import="javax.sql.DataSource"%>
<%@page import="javax.naming.*"%>
<html>
<body>
<%
try{
Context initCtx=new InitialContext();
DataSource db = (DataSource)initCtx.lookup("java:comp/env/jdbc/chen");
Connection conn = db.getConnection();
ResultSet rs=null;
Statement stmt = conn.createStatement();
String sql="select * from user limit 10";
rs = stmt.executeQuery(sql);
out.println("User-list"+"<br>");
while(rs.next()){
out.print("id is"+rs.getString("id")+"<br>");
out.print("name is"+rs.getString("username")+"<br>");
}
rs.close();
stmt.close();
conn.close();
}
catch(Exception e){
out.print(e);
}
%>
</body>
</html>
[/code]
Resource项(即连接池的DataSource对象),有3个属性name、auth、type,name项是JNDI的名称定义,程序通过JNDI才能找到此对象,这里取名jdbc/LJJ;auth项即连接池管理权属性,这里取值Container,申明为容器管理;type项即对象的类型,这里取值javax.sql.DataSource,申明为数据库连接池。
在接下来的<ResourceParams>域内容里包含四个参数username、password、driverClassName、url,依次为数据库的用户名、密码、JDBC驱动和数据库地址
在实际应用开发中,特别是在WEB应用系统中,如果JSP、Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,如果频繁发生这种数据库操作,系统的性能必然会急剧下降,甚至会导致系统崩溃。数据库连接池技术是解决这个问题最常用的方法,在许多应用程序服务器(例如:Weblogic, WebSphere,JBoss)中,基本都提供了这项技术,无需自己编程,但是,深入了解这项技术是非常必要的。

  数据库连接池技术的思想非常简单,将数据库连接作为对象存储在一个Vector对象中,一旦数据库连接建立后,不同的数据库访问请求就可以共享这些连接,这样,通过复用这些已经建立的数据库连接,可以克服上述缺点,极大地节省系统资源和时间。

  数据库连接池的主要操作如下:

  (1)建立数据库连接池对象(服务器启动)。

  (2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。

  (3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接。

  (4)存取数据库。

  (5)关闭数据库,释放所有数据库连接(此时的关闭数据库连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。

  (6)释放数据库连接池对象(服务器停止、维护期间,释放数据库连接池对象,并释放所有连接)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值