spring c3p0 java_spring c3p0的配置

1.1 Spring相关jar包引入(共9个jar包)

首先是配置spring容器jar:(context(上下文字段),core(spring核心包),expression(spring表达式),bean(生产和装配bean的工厂),

common-logging(spring  中bean是从aprache引入的,所以要提供logging依赖)):

a.spring核心容器图

37fb6206b6f25554c41d9a60096304aa.png

、        b.spring核心容器jar支持

09c0b9c6010c903736a1f9eb649beab5.png

1.2 Spring JdbcTemplate 里面c3p0支持的 jar包引入

a.jdbc驱动引入

f1a923669bbbfc350f4d727dcba0b50b.png

b.Spring jdbcTemplate的相关的jar引入

1528d963987c7162fdf8572f91e59d95.png

c.c3p0的相关的jar引入

d6939ee4d1563d3c19ec3bc7ed69f4f4.png

2.数据库准备

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

Source Server : gg

Source Host : localhost:3306Source Database: spring_database

Target Server Type : MYSQL

File Encoding : 65001Date: 2017-03-08 14:27:35

*/

SET FOREIGN_KEY_CHECKS=0;

--------------------------------Table structure for t_user------------------------------

DROP TABLE IF EXISTS`t_user`;

CREATE TABLE`t_user` (

`_id` int(11) NOT NULLAUTO_INCREMENT,

`username` varchar(50) DEFAULT NULL,

`userpwd` varchar(32) DEFAULT NULL,

PRIMARY KEY(`_id`)

) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;

--------------------------------Records of t_user------------------------------

INSERT INTO `t_user` VALUES ('1', 'jake', '123456');

INSERT INTO `t_user` VALUES ('2', 'rose', '123456789');

INSERT INTO `t_user` VALUES ('3', 'tom', '999');

View Code

3.编码测试

2.1 User的标准JavaBean设计

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

/*** 标准JavaBean

* @authorGGR

*

*/

public classUser {

@Override

publicString toString() {

//TODO Auto-generated method stub

return super.toString();

}

private Integer _id;//用户id

private String username;//用户名

private String userpwd;//用户密码

publicUser(){}

publicUser(String username,String userpwd){

this.username =username;

this.setUserpwd(userpwd);

}

publicString getUsername() {

returnusername;

}

public voidsetUsername(String username) {

this.username =username;

}

publicString getUserpwd() {

returnuserpwd;

}

public voidsetUserpwd(String userpwd) {

this.userpwd =userpwd;

}

publicInteger get_id() {

return_id;

}

public voidset_id(Integer _id) {

this._id =_id;

}

}

View Code

2.2 普通方式使用c3p0连接池

a.1 直接在UserDao里面测试

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

importjava.beans.PropertyVetoException;

importorg.springframework.jdbc.core.JdbcTemplate;

importcom.mchange.v2.c3p0.ComboPooledDataSource;

public classUserDao {

public static void main(String[] args) throwsPropertyVetoException {

/*** c3p0连接池数据源配置

* 1.创建dataSources连接池对象

* 2.初始化连接池的4项基本配置(4项基本配置是所有种类的连接池都必须配置的)

* a.驱动名称 DriverClass

* b.数据库地址 JdbcUrl

* c.用户名 User

* d.密码 Password

*/ComboPooledDataSource dataSource = newComboPooledDataSource();

dataSource.setDriverClass("com.mysql.jdbc.Driver");

dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/spring_database");

dataSource.setUser("root");

dataSource.setPassword("362427gg");

//创建模板工具类

JdbcTemplate jdbcTemplate = newJdbcTemplate();

jdbcTemplate.setDataSource(dataSource);

jdbcTemplate.update("insert into t_user(username,userpwd)values(?,?)", "tom","999");

}

}

View Code

a.2. 测试结果

d8036c8d9814aea7aba4fad054e31e62.png

2.3 使用c3p0连接池结合Spring容器

a.1思路:将所有的对象创建和管理权交给spring的容器(IOC/DI)

在src下创建bean.xml文件:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

View Code

a.2编写测试代码

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

packagecom.heima_jdbctemplate_c3p0;

importorg.junit.Test;

importorg.springframework.context.ApplicationContext;

importorg.springframework.context.support.ClassPathXmlApplicationContext;

importorg.springframework.jdbc.core.JdbcTemplate;

public classTestdamo {

@Test

public voiddemo(){

String xmlpath = "com/heima_jdbctemplate_c3p0/bean.xml";

ApplicationContext context = newClassPathXmlApplicationContext(xmlpath);

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

jdbcTemplate.update("insert into t_user(username,userpwd)values(?,?)", "tom","362427");

}

}

View Code

a.3测试结果

783b3e1161c9679d0ffcbb9b4bcc9550.png

cdb86b6e2f12a9986e89bd60b3979cd7.png

2.4 使用c3p0连接池结合Spring容器(使用JdbcDaoSupport+注解+properties配置文件完成UserDao的设计)

将配置信息直接写到spring的bean.xml显然不够灵活,我们需要将连接池配置信息写到properties文件里面,这样方便修改和维护。

a.1 UserDao设计

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

importjava.util.List;

importorg.springframework.jdbc.core.simple.ParameterizedBeanPropertyRowMapper;

importorg.springframework.jdbc.core.support.JdbcDaoSupport;

/*** 用户操作dao

* @authorGGR

* ParameterizedBeanPropertyRowMapper提供里数据库每行每个参数到bean对象每个属性的映射

*/

public class UserDao extendsJdbcDaoSupport{

public ListgetAll(){

return this.getJdbcTemplate().query("select* from t_user",ParameterizedBeanPropertyRowMapper.newInstance(User.class));

}

publicUser QuerybyId(Integer _id){

return this.getJdbcTemplate().queryForObject("select* from t_user where _id=?", ParameterizedBeanPropertyRowMapper.newInstance(User.class),_id);

}

}

View Code

a.2 jdbcinfo.properties相关配置

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

jdbc.driverClass=com.mysql.Driver

jdbc.jdbcUrl=jdbc:mysql://localhost:3306/spring_database

jdbc.user=root

jdbc.password=362427gg

View Code

a.3 bean.xml相关配置

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

View Code

a.4测试代码

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

packagecom.heima_jdbctemplate_c3p0;

importorg.junit.Test;

importorg.springframework.context.ApplicationContext;

importorg.springframework.context.support.ClassPathXmlApplicationContext;

importorg.springframework.jdbc.core.JdbcTemplate;

public classTestdamo {

@Test

public voiddemo(){

String xmlpath = "com/heima_jdbctemplate_c3p0/bean.xml";

ApplicationContext context = newClassPathXmlApplicationContext(xmlpath);

UserDao dao = (UserDao) context.getBean("userdao");

System.out.println(dao.getAll());

}

}

View Code

a.5测试结果

aa914b1501e5c1579e1372573b70f49d.png

总结:这里只是c3p0连接池的简单使用,主要是为了和Spring进行整合。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值