Spring&Mybatis整合及Spring中JDBCTemplate的使用

Spring和Mybatis整合

在mybatis中,操作数据库需要获取到SQLSession对象,而该对象的实例过程在mybatis是通过SQLSessionFactoryBuilder读取全局配置文件来实例化一个SQLSessionFactory,通过SQLSessionFactory来获取到SQLSession对象,而和spring整合过程中,可以通过单例的形式来管理SQLSessionFactory对象,mybatis-spring中提供了一个SQLSessionFactoryBean类来实例化SQLSessionFactory,SQLSessionFactory中需要必须的属性是DataSource与Mappers。

整合步骤如下

1、引入mybatis-spring

为了完成spring和mybatis的整合,由mybatis提供了一个整合jar包:mybatis-spring

        <!--mybatis和spring整合依赖-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.3.0</version>
        </dependency>

完整的依赖文件如下:

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

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>org.example</groupId>
  <artifactId>springTest</artifactId>
  <version>1.0-SNAPSHOT</version>

  <name>springTest</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-core</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-beans</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-expression</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-aop</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.aspectj</groupId>
      <artifactId>aspectjweaver</artifactId>
      <version>1.7.4</version>
    </dependency>

    <dependency>
      <groupId>aopalliance</groupId>
      <artifactId>aopalliance</artifactId>
      <version>1.0</version>
    </dependency>

    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.12</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>5.2.8.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.39</version>
    </dependency>

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.3.0</version>
    </dependency>

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.4.1</version>
    </dependency>

    <dependency>
      <groupId>com.mchange</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.5.2</version>
    </dependency>

  </dependencies>

  <build>
    <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
      <plugins>
        <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-jar-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
        <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
        <plugin>
          <artifactId>maven-site-plugin</artifactId>
          <version>3.7.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-project-info-reports-plugin</artifactId>
          <version>3.0.0</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>

2.开发过程

mybatis全局配置文件(可以忽略)、Pojo类、Mapper.java接口文件和Mapper.xml配置文件

StudentMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.example.dao.StudentMapper">
    <select id="selectStudentById" parameterType="int" resultType="org.example.bean.Student1">
        select * from Student where SID = #{SID}
    </select>
</mapper>

 Student1

package org.example.bean;

/**
 * Description :
 * Created by Resumebb
 * Date :2021/3/26
 */
public class Student1 {
    /**
     * 和数据库中的Student表对应
     */
    private Integer SID;
    private String Sname;
    private String Ssex;
    private Integer Sage;
    //省略的getter和setter方法

    public Integer getSID() {
        return SID;
    }

    public void setSID(Integer SID) {
        this.SID = SID;
    }

    public String getSname() {
        return Sname;
    }

    public void setSname(String sname) {
        Sname = sname;
    }

    public String getSsex() {
        return Ssex;
    }

    public void setSsex(String ssex) {
        Ssex = ssex;
    }

    public Integer getSage() {
        return Sage;
    }

    public void setSage(Integer sage) {
        Sage = sage;
    }

    @Override
    public String toString() {
        return "com.pojo{" +
                "SID=" + SID +
                ", Sname='" + Sname + '\'' +
                ", Ssex='" + Ssex + '\'' +
                ", Sage=" + Sage +
                '}';
    }
}

3.spring-mybatis.xml配置 

根据数据库信息注入数据源,并将相应的映射文件加载至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-3.0.xsd">

    <bean id="dataSource" class="com.mchange.v2.c3p0.DriverManagerDataSource">
        <property name="driverClass" value="com.mysql.jdbc.Driver"></property>
        <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"></property>
        <property name="user" value="root"></property>
        <property name="password" value="123456"></property>
    </bean>

    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--        数据源配置-->
        <property name="dataSource" ref="dataSource"></property>
<!--        加载mybatis配置文件-->
        <property name="configLocation" value="mybatis-config.xml"></property>
        <property name="mapperLocations" value="mapper/*.xml"></property>
    </bean>

<!--    获取Studentapper的代理对象-->
    <bean id="studentMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
        <property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
        <property name="mapperInterface" value="org.example.dao.StudentMapper"></property>
    </bean>
</beans>

4.测试

public class MybatisDemo {
    public static void main(String[] args) {
        String path = "spring-mybatis.xml";

        ClassPathXmlApplicationContext classContext = new ClassPathXmlApplicationContext(path);
        StudentMapper studentMapper  = (StudentMapper)classContext.getBean("studentMapper");
        Student1 student1 = studentMapper.selectStudentById(1);
        System.out.println(student1);
    }
}

 

Spring中JDBCTemplate的使用

jdbcTemplate操作步骤

导入相关依赖

      <!--spring支持jdbc模板操作-->
     <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>5.2.8.RELEASE</version>
     </dependency>

     <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>5.2.8.RELEASE</version>
     </dependency>

      <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.39</version>
      </dependency>

 

JDBCTemplate的使用

public class JDBCTemplateDemo {
    public static void main(String[] args) {

        //创建对象,设置数据源信息
        DriverManagerDataSource driverManagerDataSource = new DriverManagerDataSource();
        driverManagerDataSource.setDriverClassName("com.mysql.jdbc.Driver");
        driverManagerDataSource.setUrl("jdbc:mysql://localhost:3306/test");
        driverManagerDataSource.setUsername("root");
        driverManagerDataSource.setPassword("123456");

        //获取jdbc模板实例
        JdbcTemplate jdbcTemplate = new JdbcTemplate(driverManagerDataSource);

        //通过模板对象调用方法来执行相关操作
        //通过jdbcTemplate提供的update方法来完成变更操作(修改、新增、删除)
        //删除操作SQL
        String deleteSql = "delete from Student where SID = ?";
        int update = jdbcTemplate.update(deleteSql, new Object[]{22});
        System.out.println(update);

        //查询操作(单个对象) 使用queryForObject方法
        String selectSql1 = "select * from Student where SID = ?";
        Student1 student1 = jdbcTemplate.queryForObject(selectSql1, new Object[]{1}, new StudentMapper());
        System.out.println(student1);

        //查询操作(多个结果集对象) 使用query方法
        String selectSql2 = "select * from Student";
        List <Student1> student1List = jdbcTemplate.query(selectSql2, new StudentMapper());
        Iterator <Student1> iterator = student1List.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }

    }
}

JDBCTemplate解决了JDBC结果集合Java代码的耦合性问题

实现一个RowMapper接口的实现类,手动完成数据库结果集和Java对象的映射

public class StudentMapper implements RowMapper<Student1> {
    @Override
    /**
     * jdbc模板能够完成自动映射为Java对象关键点在于实现RowMapper接口
     * 实现mapRow方法
     * ResultSet:数据库结果集
     * int :类似数据库数据序号,从0开始
     * 返回类型:指定的Java对象
     * 该方法主要是完成ResultSet结果集手动映射为Java对象
     *
     */
    public Student1 mapRow(ResultSet resultSet, int i) throws SQLException {
        Student1 student1 = new Student1();
        student1.setSID(resultSet.getInt("SID"));
        student1.setSage(resultSet.getString("Sage"));
        student1.setSname(resultSet.getString("Sname"));
        student1.setSsex(resultSet.getString("Ssex"));

        return student1;
    }
}

不管是单个结果集还是多个结果集都会代用到在RowMapper接口的实现类,数据库中每一条记录都会执行到mapRow方法。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值