JDBC之连接池: Tomcat 8.5 MySQL数据库连接池的配置与使用

简介

本文以MySQL数据库为例,介绍Tomcat 8.5环境下,其默认的数据库连接池DBCP配置与使用.

连接池简介

数据库连接池是在用户和数据库之间创建一个”池”,这个池是用来存放数据库连接对象。回收和重用已存在的数据库连接比新建一个连接更高效。当用户想要连接数据库,就要先从连接池中获取连接对象,然后操作数据库; 操作完成后,将连接对象归还给连接池。一旦连接池中的连接对象被取完,下一个想要操作数据库的用户必须等待其他用户释放连接对象,从而获取连接对象并操作数据库。

配置步骤

1. MySQL配置

创建测试用的数据库,测试用户和单个测试表。

mysql> GRANT ALL PRIVILEGES ON *.* TO javauser@localhost
    ->   IDENTIFIED BY 'javadude' WITH GRANT OPTION;
mysql> create database javatest;
mysql> use javatest;
mysql> create table testdata (
    ->   id int not null auto_increment primary key,
    ->   foo varchar(25),
    ->   bar int);
mysql> insert into testdata values(null, 'hello', 12345);
Query OK, 1 row affected (0.00 sec)

mysql> select * from testdata;
+----+-------+-------+
| ID | FOO   | BAR   |
+----+-------+-------+
|  1 | hello | 12345 |
+----+-------+-------+
1 row in set (0.00 sec)

mysql>

2. Context配置

通过在tomcat安装目录下conf/context.xml配置文件增加资源声明来配置JNDI DataSource。



    

    

    

    

    

    

  

3. web.xml配置

在WEB-INF/web.xml中添加下列的配置项:

  
      DB Connection
      jdbc/TestDB
      javax.sql.DataSource
      Container
  
4. 测试

通过下列简单的JSP文件test.jsp来对用户信息进行测试

<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>


select id, foo, bar from testdata



  
    DB Test
  
  

  

Results

Foo ${row.foo}
Bar ${row.bar}

你可能感兴趣的:(MySQL,Java)