zoukankan      html  css  js  c++  java
  • JDBCTemplate

    、Spring对不同的持久化支持:

    Spring为各种支持的持久化技术,都提供了简单操作的模板和回调

    ORM持久化技术 模板类
    JDBC org.springframework.jdbc.core.JdbcTemplate
    Hibernate5.0 org.springframework.orm.hibernate5.HibernateTemplate
    IBatis(MyBatis) org.springframework.orm.ibatis.SqlMapClientTemplate
    JPA org.springfrmaework.orm.jpa.JpaTemplate

    其实Spring的JDBCTemplate有点像DBUtils,但是有时候还没有DBUitls好用。这里来学习一下使用Spring的JDBCTemplate来玩一下CRUD。

    二、使用JdbcTemplate需要的jar包

    在这里使用Spring的JDBCTemplate的时候先要把轮子拿过来:

    image

    除此之外,在Java中操作数据库怎么能不要对应的驱动包呢:

    image

    三、JdbcTemplate使用的基本步骤

    然后再看看Spring的JDBCTemplate的使用大体步骤,这里有一个小例子:

    复制代码
      1 package com.spring.test;
      2 
      3 import org.junit.Test;
      4 import org.springframework.jdbc.core.JdbcTemplate;
      5 import org.springframework.jdbc.datasource.DriverManagerDataSource;
      6 
      7 public class TestJDBCTemplate {
      8 
      9     @Test
     10     public void test1() {
     11 
     12         // JDBC模板依赖于连接池来获得数据的连接,所以必须先要构造连接池
     13         DriverManagerDataSource dataSource = new DriverManagerDataSource();
     14         dataSource.setDriverClassName("com.mysql.jdbc.Driver");
     15         dataSource.setUrl("jdbc:mysql://localhost:3306/spring");
     16         dataSource.setUsername("root");
     17         dataSource.setPassword("123456");
     18 
     19         // 创建JDBC模板
     20         JdbcTemplate jdbcTemplate = new JdbcTemplate();
     21         // 这里也可以使用构造方法
     22         jdbcTemplate.setDataSource(dataSource);
     23 
     24         // sql语句
     25         String sql = "select count(*)  from user";
     26         Long num = (long) jdbcTemplate.queryForObject(sql, Long.class);
     27 
     28         System.out.println(num);
     29 
     30     }
     31 
     32 }
    复制代码

    四、进一步的考虑

    其实这个例子本身没有什么的,只是演示了一下,其实在学Spring之后,感觉应该形成一种习惯,在new对象的时候我要想到IOC,在使用Set方法的时候,我要想到DI,再去要方便面(哦,不,是切面),我们应该想到用AOP的。这里可以在Spring中配置如下的引用链:

    1. 我要有DataSource,DataSource的属性可以通过注入数据库的一些配置属性添加

    2. 我要有JdbcTemplate,而Template依赖与DataSource,我要以ref的方式为我的JdbcTemplate注入引用

    3. 有了JdbcTemplate之后,我要有Dao,此时我应该在Dao添加一个JdbcTemplate的成员,然后以ref的方式将JdbcTemplate引入到Dao中

    4. 我在Action或者是Servlet中都会调用的是Serivce,所以,我在Serivce中要添加一个Dao作为成员,然后由ref在注入Dao到Service中

    DataSource --> JdbcTemplate --> Dao --> Service --> Action/Servlet

    "-->"表示将左边的对象注入到右边的对象当中

    配置文件如下:

    复制代码
      1 <?xml version="1.0" encoding="UTF-8"?>
      2 <beans xmlns="http://www.springframework.org/schema/beans"
      3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      4     xmlns:context="http://www.springframework.org/schema/context"
      5     xmlns:aop="http://www.springframework.org/schema/aop"
      6     xmlns:tx="http://www.springframework.org/schema/tx"
      7     xsi:schemaLocation="http://www.springframework.org/schema/beans
      8     http://www.springframework.org/schema/beans/spring-beans.xsd
      9     http://www.springframework.org/schema/context
     10     http://www.springframework.org/schema/context/spring-context.xsd
     11     http://www.springframework.org/schema/aop
     12     http://www.springframework.org/schema/aop/spring-aop.xsd
     13     http://www.springframework.org/schema/tx
     14     http://www.springframework.org/schema/tx/spring-tx.xsd">
     15 
     16     <!-- IOC和DI的注解扫描 -->
     17     <context:component-scan base-package="com.spring" ></context:component-scan>
     18 
     19     <!-- 打开AOP的注解 -->
     20     <!-- 这里用的是中间的横线而不是下划线 -->
     21     <aop:aspectj-autoproxy></aop:aspectj-autoproxy>
     22 
     23     <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" >
     24         <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/spring_03"></property>
     25         <property name="driverClass" value="com.mysql.jdbc.Driver"></property>
     26         <property name="user" value="root"></property>
     27         <property name="password" value="123456"></property>
     28     </bean>
     29 
     30     <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
     31         <property name="dataSource" ref="dataSource"></property>
     32     </bean>
     33 
     34     <bean id="userDao" class="com.spring.dao.UserDao">
     35         <property name="jdbcTemplate" ref="jdbcTemplate"></property>
     36     </bean>
     37 
     38     <bean id="userService" class="com.spring.service.UserService">
     39         <property name="userDao" ref="userDao"></property>
     40     </bean>
     41 
     42 </beans>
    复制代码

    其中dataSource和jdbcTemplate都是直接配置的,不用写啥。

    然后是UserDao.java

    复制代码
      1 package com.spring.dao;
      2 
      3 import org.springframework.jdbc.core.JdbcTemplate;
      4 
      5 import com.spring.domain.User;
      6 
      7 public class UserDao {
      8 
      9     private JdbcTemplate jdbcTemplate;
     10 
     11     public JdbcTemplate getJdbcTemplate() {
     12         return jdbcTemplate;
     13     }
     14 
     15     public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
     16         this.jdbcTemplate = jdbcTemplate;
     17     }
     18 
     19     public void addUser(User user) {
     20 
     21         String sql = "insert into user (username, password) values (?, ?)";
     22 
     23         jdbcTemplate.update(sql, user.getUsername(), user.getPassword());
     24 
     25     }
     26 
     27 }
    复制代码

    UserSerice.java

    复制代码
      1 package com.spring.service;
      2 
      3 import com.spring.dao.UserDao;
      4 import com.spring.domain.User;
      5 
      6 public class UserService {
      7 
      8     // 加入userDao作为成员变变量
      9     private UserDao userDao;
     10 
     11     // 注意这里要增加get和set方法
     12     public UserDao getUserDao() {
     13         return userDao;
     14     }
     15 
     16     public void setUserDao(UserDao userDao) {
     17         this.userDao = userDao;
     18     }
     19 
     20     public void addUser(User user) {
     21         userDao.addUser(user);
     22     }
     23 }
    复制代码

    上面的文件都是用的配置文件来获得对象的,而没有使用注解。

    测试类:

    复制代码
      1 package com.spring.test;
      2 
      3 import org.junit.Test;
      4 import org.springframework.context.ApplicationContext;
      5 import org.springframework.context.support.ClassPathXmlApplicationContext;
      6 import com.spring.domain.User;
      7 import com.spring.service.UserService;
      8 
      9 public class TestJDBCTemplate {
     10 
     11     @Test
     12     public void test2() {
     13 
     14         ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
     15         UserService userService = (UserService) ctx.getBean("userService");
     16 
     17         User user = new User();
     18         user.setPassword("111");
     19         user.setUsername("小王");
     20 
     21         userService.addUser(user);
     22 
     23     }
     24 
     25 }
    复制代码

    哦,对了其中配置的数据源是C3P0的数据源,还要导入C3P0的包:

    image

    五、JdbcTemplate的CRUD方法

    1. 插入数据

    复制代码
      1 public void addUser(User user) {
      2 
      3     String sql = "insert into user (username, password) values (?, ?)";
      4 
      5     jdbcTemplate.update(sql, user.getUsername(), user.getPassword());
      6 
      7 }
    复制代码

    如上,插入代码用的是update方法,其实增删改用的都是update方法,而查询则是和query相关的方法。

    2. 删除操作

      1 public void deleteUser( ) {
      2     String sql = "delete from user where username= ?";
      3     jdbcTemplate.update(sql, "小王");
      4 }

    3. 修改操作

      1 public void updateUser(User user) {
      2     String sql = "update user set username=? where username= ?";
      3     jdbcTemplate.update(sql,  user.getUsername() + "_new", user.getUsername());
      4 }

    4. 查询操作

    上面三个都比较简单,查询倒是有些复杂。在使用比较基础的持久化工具的时候,比如DBUtils都会针对查询结果给我们提供一些封装的接口和类,但是JdbcTemplate只给我们提供了接口,并没有可用的类,所以我们需要自己写实现类来进行封装。这里会学习使用JdbcTemplate进行三种查询操作:

    4.a. 查询表的记录数

    image

    复制代码
      1 @Test
      2 public void test5() {
      3     ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
      4     JdbcTemplate jdbcTemplate = (JdbcTemplate) ctx.getBean("jdbcTemplate");
      5     String sql = "select count(*) from user";
      6     Long row = jdbcTemplate.queryForObject(sql, Long.class);
      7     System.out.println("查询出来的记录数为:" + row);
      8 }
    复制代码

    4.b. 查询返回对象

    image

    复制代码
      1 @Test
      2 public void test6() {
      3     // 获得jdbcTemplate对象
      4     ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
      5     JdbcTemplate jdbcTemplate = (JdbcTemplate) ctx.getBean("jdbcTemplate");
      6     String sql = "select username, password from user where username = ?";
      7     // 设定参数
      8     Object[] object = {"mary_new"};
      9     // 进行查询
     10     User user = jdbcTemplate.queryForObject(sql, object,  new UserMapper());
     11     System.out.println(user);
     12 }
    复制代码

    除此之外要实现结构RowMapper来新建一个映射类:

    复制代码
      1 package com.spring.test;
      2 
      3 import java.sql.ResultSet;
      4 import java.sql.SQLException;
      5 
      6 import org.springframework.jdbc.core.RowMapper;
      7 
      8 import com.spring.domain.User;
      9 
     10 public class UserMapper implements RowMapper<User>{
     11 
     12     @Override
     13     public User mapRow(ResultSet resultSet, int rows) throws SQLException {
     14         User user = new User();
     15         user.setUsername(resultSet.getString(1));
     16         user.setPassword(resultSet.getString(2));
     17 
     18         return user;
     19     }
     20 
     21 }
    复制代码

    要注意这个UserMapper.java应该要和具体的Sql语句对应。

    4.c. 查询并返回List集合

    image

    复制代码
      1 @Test
      2 public void test7() {
      3     // 获得jdbcTemplate对象
      4     ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
      5     JdbcTemplate jdbcTemplate = (JdbcTemplate) ctx.getBean("jdbcTemplate");
      6 
      7     // sql语句
      8     String sql = "select * from user";
      9     List<User> users = jdbcTemplate.query(sql, new UserMapper());
     10 
     11     for(User u: users) {
     12         System.out.println(u);
     13     }
     14 }
    复制代码

    什么是数据库连接池如图告诉你

    这里写图片描述

    二、使用C3P0建立连接:

    (一)描述:

    开源组织提供实现:

    C3P0 数据库连接池DataSource 通常被称为数据源,

    它包含连接池和连接池管理两个部分,

    习惯上也经常把 DataSource 称为连接池

    DataSource用来取代DriverManager来获取Connection,获取速度快,

    同时可以大幅度提高数据库访问速度。

    (二)不多说:(上干货)使用C3P0的步骤

    <1>加入jar包:

    连接MySql:

    mysql-connector-java-5.1.37-bin.jar//mysql获取驱动
    c3p0-0.09.1.2.jar                  //c3p0
    或者:

    
    

    <2>使用配置文件xml将属性配置配置文件中

    xml配置及效果:



     
     

    二、使用DBCP建立连接:

    (一)描述:

    DBCP数据源

    DBCP 是 Apache 软件基金组织下的开源连接池实现,

    该连接池依赖该组织下的另一个开源系统:Common-pool.

    pool.jar:连接池实现的依赖库

    Tomcat 的连接池正是采用该连接池来实现的。该数据库连接池既可以与应用服

    务器整合使用,也可由应用程序独立使用。

    (三)实现DBCP连接步骤:

    <1>加入jar包:

    连接MySql:

    commons-pool-1.5.5.jar              //依赖数据池
    Commons-dbcp.jar:连接池的实现        //dbcp的jar包
    mysql-connector-java-5.1.37-bin.jar //mysql获取驱动
    或者:
     

    <2>dbcp使用配置文件xml将属性配置配置文件中

      xml配置及效果:

    
    
     
  • 相关阅读:
    Redis 如何保证缓存与数据库双写时的数据一致性
    Redis 缓存雪崩和缓存穿透问题
    Redis 的并发竞争 Key 问题
    【转】intelliJ IDEA集成checkStyle
    【转】hadoop深入研究:(十一)——序列化与Writable实现
    【转】Hadoop在MapReduce中使用压缩详解
    【转】JDK工具jinfo用法详解
    【转】JVM统计监控工具-jstat
    【转】jps命令使用
    基于MLlib的机器学习--协同过滤与推荐
  • 原文地址:https://www.cnblogs.com/anzmri/p/7707886.html
Copyright © 2011-2022 走看看