欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JSP数据库连接池实例

程序员文章站 2022-04-19 17:16:00
...

数据库连接池

传统的Web服务不断连接、关闭数据库,比较消耗性能。而连接池可以减少数据库的打开与关闭。
JSP数据库连接池实例
有了连接池,当服务端的请求传来时,不需要牵扯数据库的建立和关闭。

常见连接池:Tomcat - dbcp连接池、dbcp、c3p0

数据源:DataSource(javax.sql.DataSource)可用来管理连接池。

Tomat-dbcp的配置方法:

1.类似 JNDI,在 context.xml 中进行配置:

<Context>

	<Resource 
	auth="Container" 
	driverClassName="org.gjt.mm.mysql.Driver" 
	maxIdle="20" 
	maxTotal="100" 
	maxWaitMillis="5000" 
	name="jdbc/new" 
	username="root"
	password="root" 
	type="javax.sql.DataSource" 
	url="jdbc:mysql://localhost:3306/exp6?serverTimezone=UTC"/>

</Context>

这里注意:name自己定义一个,和下边要用到的一样 ,
username 、 password 是数据库的用户名和密码,
url 写自己的数据库的 url。

2.在WEB-INF / web.xml 中配置:

<?xml version="1.0" encoding="UTF-8"?>
<web-app 	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
			xmlns="http://xmlns.jcp.org/xml/ns/javaee" 
			xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" 
			id="WebApp_ID" version="3.1">
<resource-ref>
		<description>DB Connection </description>
        <res-ref-name>jdbc/new</res-ref-name>
        <res-type>javax.sql.DataSource</res-type>
        <res-auth>Container</res-auth>
</resource-ref>
</web-app>

注意:ref-name与上边对应,其他的一样。

3.使用数据源,更改 connection 的获取方式:

将传统的代码:

connection = DriverManager.getConnection(URL, USER, PASSWORD);

改为:


Context ctx = new InitialContext();	// context.xml

DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/new");	// 与前边对应

connection = ds.getConnection();

经过以上三步,数据库连接池应该就能用了。

但是,这里要说一个问题,又是让我纠结了好久找不到答案的问题。

报错:cannot create jdbc driver of class ‘’ for connect url 'null’

它说找不到我的数据库url,但是仔细查看以上三处代码,明明没问题呀。山重水复疑无路,柳暗花明又一村。最终还是找到了一篇能解决我的问题的博客

自己经过不断的摸索发现,遇到没见过的问题一定要细心思考多查博客,尽量不要问他人(因为他人也不会呀,问了也是浪费时间)。成功 Debug 也是索然无味的生活中的一丝丝乐趣呀。

说在最后的话:编写实属不易,若喜欢或者对你有帮助记得点赞+关注或者收藏哦~

相关标签: 网页设计