---------------------siwuxie095

 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 

Spring 配置连接池

 
 

 
 

1、Spring 配置内置连接池

 
 


applicationContext.xml 中添加如下内容:

 
 

<bean
id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">

<property
name="driverClassName"
value="com.mysql.jdbc.Driver"/>

<property
name="url"
value="jdbc:mysql:///spring_db"/>

<property
name="username"
value="root"/>

<property
name="password"
value="8888"/>

</bean>

 
 

 
 

其中:

 
 

jdbc:mysql:///spring_db

jdbc:mysql://localhost:3306/spring_db
的简写

 
 


省略了
localhost:3306

 
 

 
 

 
 

 
 

2、Spring 配置 DBCP 连接池

 
 

(1)导入两个相关 jar 包

 
 

1)commons-dbcp

 
 

2)commons-pool

 
 

 
 

 
 

Commons DBCP 下载链接:

 
 

http://commons.apache.org/proper/commons-dbcp/download_dbcp.cgi

 
 

 
 

Commons Pool 下载链接:

 
 

http://commons.apache.org/proper/commons-pool/download_pool.cgi

 
 

 
 

 
 

(2)在
applicationContext.xml 中添加如下内容:

 
 

<!--

注意:由于使用的是 DBCP 2.x 版本,所以全限定名是:

 

org.apache.commons.dbcp2.BasicDataSource

 

如果使用的 DBCP 1.x 版本,则全限定名是:

 

org.apache.commons.dbcp.BasicDataSource

-->

<bean
id="dataSource"
class="org.apache.commons.dbcp2.BasicDataSource">

<property
name="driverClassName"
value="com.mysql.jdbc.Driver"/>

<property
name="url"
value="jdbc:mysql:///spring_db"/>

<property
name="username"
value="root"/>

<property
name="password"
value="8888"/>

</bean>

 
 

 
 

 
 

 
 

3、Spring 配置 C3P0 连接池

 
 

(1)导入
c3p0 的
jar 包

 
 

 
 

 
 

C3P0 下载链接:http://mvnrepository.com/artifact/c3p0/c3p0

 
 

 
 

 
 

(2)在
applicationContext.xml 中添加如下内容:

 
 

<bean
id="dataSource"
class="com.mchange.v2.c3p0.ComboPooledDataSource">

<property
name="driverClass"
value="com.mysql.jdbc.Driver"/>

<property
name="jdbcUrl"
value="jdbc:mysql:///spring_db"/>

<property
name="user"
value="root"/>

<property
name="password"
value="8888"/>

</bean>

 
 

 
 

 
 

 
 

4、Spring 配置数据库连接信息到属性文件中

 
 

(1)在
src
下创建属性文件
jdbc.properties

 
 

jdbc.driverClassName=com.mysql.jdbc.Driver

jdbc.url=jdbc:mysql:///spring_db

jdbc.username=root

 
 

 
 

(2)在
applicationContext.xml 中引入外部属性文件

 
 

1)法一:

 
 

<bean
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

<property
name="location"
value="classpath:jdbc.properties"/>

</bean>

 
 

 
 

2)法二:

 
 

<!-- 注意:此法要引入 context 约束 -->

<context:property-placeholder
location="classpath:jdbc.properties"/>

 
 

 
 

 
 

(3)在
applicationContext.xml 中配置连接池

 
 

1)法一:配置内置连接池

 
 

<bean
id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">

<property
name="driverClassName"
value="${jdbc.driverClassName}"/>

<property
name="url"
value="${jdbc.url}"/>

<property
name="username"
value="${jdbc.username}"/>

<property
name="password"
value="${jdbc.password}"/>

</bean>

 
 

 
 

2)法二:配置
DBCP 连接池

 
 

<bean
id="dataSource"
class="org.apache.commons.dbcp2.BasicDataSource">

<property
name="driverClassName"
value="${jdbc.driverClassName}"/>

<property
name="url"
value="${jdbc.url}"/>

<property
name="username"
value="${jdbc.username}"/>

<property
name="password"
value="${jdbc.password}"/>

</bean>

 
 

 
 

3)法三:配置
C3P0 连接池

 
 

<bean
id="dataSource"
class="com.mchange.v2.c3p0.ComboPooledDataSource">

<property
name="driverClass"
value="${jdbc.driverClassName}"/>

<property
name="jdbcUrl"
value="${jdbc.url}"/>

<property
name="user"
value="${jdbc.username}"/>

<property
name="password"
value="${jdbc.password}"/>

</bean>

 
 

 
 

 
 

参考链接:

 
 

参考链接1参考链接2

 
 

 
 

 
 

 
 

5、以内置连接池为例,进行测试

 
 

(1)在
MySQL 中手动创建数据库和表

 
 

数据库名:spring_db,表名:user,字段:username、password

 
 

 
 

 
 

 
 

(2)编写一个测试类

 
 

JdbcTemplateDemo.java:

 
 

package com.siwuxie095.jdbc;

 
 

import org.junit.Test;

import org.springframework.context.ApplicationContext;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import org.springframework.jdbc.core.JdbcTemplate;

 
 

public class JdbcTemplateDemo {

 

/**

* 手动加上 @Test 以进行单元测试(将自动导入 JUnit 4 的 jar 包)

*

* 选中方法名,右键->Run As->JUint Test

*/

@Test

public
void add() {

 

ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");

 

JdbcTemplate jdbcTemplate=(JdbcTemplate) context.getBean("jdbcTemplate");

 

String sql="insert into user values(?,?)";

 

/**

* 调用 update() 方法实现添加,返回值是 int 型,

* 创建以接收,表示在数据库中影响的行数

*/

int row=jdbcTemplate.update(sql, "小强","4321");

System.out.println(row);

}

 
 

}

 
 

 
 

 
 

(3)在配置文件中进行配置

 
 

applicationContext.xml:

 
 

<?xml
version="1.0"
encoding="UTF-8"?>

<beans
xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans.xsd">

 

 

 

<!-- 配置内置连接池 -->

<bean
id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">

<property
name="driverClassName"
value="com.mysql.jdbc.Driver"/>

<property
name="url"
value="jdbc:mysql:///spring_db"/>

<property
name="username"
value="root"/>

<property
name="password"
value="8888"/>

</bean>

 
 

 
 

<!-- 配置对象 -->

<bean
id="jdbcTemplate"
class="org.springframework.jdbc.core.JdbcTemplate">

<!--

把对象 dataSource 传递到模板对象 jdbcTemplate 中

 

在 JdbcTemplate 源代码中有属性 dataSource 和其 set 方法,所以可以注入

-->

<property
name="dataSource"
ref="dataSource"></property>

</bean>

 
 

 
 

</beans>

 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 

【made by siwuxie095】

Spring配置连接池的更多相关文章

  1. spring配置连接池和dao使用jdbcTemplate

    1 spring配置c3p0连接池 第一步 导入jar包 第二步 创建spring配置文件,配置连接池 (1)把代码中的实现在配置文件中实现 2 dao使用jdbcTemplate (1) 创建ser ...

  2. Spring配置连接池和 Dao 层使用 jdbcTemplate

    1.Spring 配置 c3p0 连接池 (1)导入jar包(Maven项目) <dependency> <groupId>com.mchange</groupId> ...

  3. Spring c3p0连接池配置

    数据库连接池 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接 ...

  4. Spring c3p0连接池无法释放解决方案

    通过c3p0配置连接池的时候,在进行压力测试的时候,日志出现了这样一个错误:Data source rejected establishment of connection, message from ...

  5. springboot2.0配置连接池(hikari、druid)

    springboot2.0配置连接池(hikari.druid) 原文链接:https://www.cnblogs.com/blog5277/p/10660689.html 原文作者:博客园--曲高终 ...

  6. [转帖]springboot2.0配置连接池(hikari、druid)

    springboot2.0配置连接池(hikari.druid) 原文链接:https://www.cnblogs.com/blog5277/p/10660689.html 原文作者:博客园--曲高终 ...

  7. 转!数据库连接池概念、种类、配置(DBCP\C3P0\JndI与Tomact配置连接池)

    数据库连接池概念.种类.配置(DBCP\C3P0\JndI与Tomact配置连接池) 一.DBCP 连接:DBCP 连接池是 Apache 软件基金组织下的一个开源连接池实现. 需要的 java 包c ...

  8. Tomcat上配置连接池{ connect error=Name [jdbc/OracleDB] is not bound in this Context. Unable to find [jdbc]}

    . 在学习期间,从未实践过在tomcat上配置连接池,今天终于实现一次,在tomcat玩了一把,不知道你是否现在有和我一样的困境.废话少说直接上代码   java  public static Con ...

  9. Tomcat 配置连接池

    1. Tomcat 配置 JNDI 资源 JNDI(Java Naming and Directory Interface), Java 命名和目录接口; JNDI 作用: 在服务器上配置资源, 然后 ...

随机推荐

  1. hdu 1966 Pie

    Pie Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...

  2. Fragment之介绍(转)

    http://www.cnblogs.com/plokmju/p/3239265.html 前言 开门见山开篇名义,本篇博客将讲解一下Android中Fragment的内容,必要的地方会提供相应的演示 ...

  3. VS2013下.Net Framework4配置FineUI4.14

    配置步骤: 工具箱:空白处右键--选项卡--浏览,选择FineUI.dll配置web.config,管道模式设置为:传统 配置web.config 在form表单下添加: <f:PageMana ...

  4. 第2课 C 到 C++ 的升级

    1.  C与C++的关系 (1)C++继承了所有的C特性,并在C的基础上提供了更多的语法和特性. (2)C++的设计目标是运行效率与开发效率的统一,它更强调的是语言的实用性. 2. C到C++ 的升级 ...

  5. 如何分析 WindowsDump:Dump 起源与初始设置

    https://www.qcloud.com/community/article/511817 转者注:让我感觉以前看蓝屏都白看了~~~原来蓝屏也可以分析具体原因. 适用场景:Windows 系列系统 ...

  6. Tensorflow图像操作

    图像操作 图像基本概念 在图像数字化表示当中,分为黑白和彩色两种.在数字化表示图片的时候,有三个因素.分别是图片的长.图片的宽.图片的颜色通道数.那么黑白图片的颜色通道数为1,它只需要一个数字就可以表 ...

  7. 解决问题E: 无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用)

    在用sudo apt-get install 安装软件时,结果终端提示: “E: 无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用) E: 无法锁定管理目录(/ ...

  8. 好久没玩laravel了,5.6玩下(二)

    做个项目的增删改查 第一步  把数据库的表结构建好,生成迁移 1 怎么建,当然是用php artisan命令了 使用 Artisan 命令 make:migration 来创建一个新的迁移: php ...

  9. FireFox 火狐主页被劫持

    火狐主页被劫持hao123,流氓 WIN7 ,firefox,任务栏,快速启动,右键 属性 target 应该是 "D:\Program Files (x86)\Mozilla Firefo ...

  10. Spring boot @ConfigurationProperties 和@Value

      @ConfigurationProperties @Value 功能 批量注入配置文件中的属性 一个个指定 松散绑定(松散语法) 支持 不支持 SpEL 不支持 支持 JSR303数据校验 支持 ...