MyBatis快速入门(四) MyBatis和Spring集成

简介: 导入依赖包前面介绍了MyBatis的相关知识,现在来介绍一下如何和Spring进行集成。MyBatis和Spring的集成工作是由MyBatis团队完成的。

导入依赖包

前面介绍了MyBatis的相关知识,现在来介绍一下如何和Spring进行集成。MyBatis和Spring的集成工作是由MyBatis团队完成的。所以我们首先要先引入MyBatis和Spring的集成依赖包。这里我用的是Gradle,如果使用其他构建工具,将下面的语句改为相应的。

compile group: 'org.mybatis', name: 'mybatis-spring', version: '1.3.1'

声明Spring Bean

集成包中包含了org.mybatis.spring.SqlSessionFactoryBean类,这是一个工厂类,可以方便的创建MyBatis的SqlSessionFactory。所有属性均可以通过该类进行设置。如果希望使用传统的XML配置的话,也可以直接设置configLocation属性为MyBatis配置文件。

<!--MyBatis的SqlSessionFactory-->
<bean id="sqlSessionFactory"
      class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="configLocation" value="configuration.xml"/>
</bean>
<!--数据源-->
<bean id="dataSource"
      class="com.mysql.jdbc.jdbc2.optional.MysqlConnectionPoolDataSource">
    <property name="user" value="root"/>
    <property name="password" value="12345678"/>
    <property name="url" value="jdbc:mysql://localhost:3306/test"/>
    <property name="useSSL" value="false"/>
</bean>

事务管理

MyBatis是一个轻量级的框架,没有自己的事务管理器。我们直接使用JDBC事务管理器即可。其它地方和别的事务配置方法差不多,就不详细介绍了。

<!--MyBatis使用JDBC的事务管理器-->
<bean id="transactionManager"
      class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>
</bean>
<tx:advice id="txAdvice"
           transaction-manager="transactionManager">
    <tx:attributes>
        <tx:method name="get*" read-only="true"/>
        <tx:method name="*"/>
    </tx:attributes>
</tx:advice>
<!--使用AOP设置事务管理-->
<aop:config>
    <aop:pointcut id="dao"
                  expression="execution(* yitian.study.dao.*.*(..))"/>
    <aop:advisor advice-ref="txAdvice" pointcut-ref="dao"/>
</aop:config>

使用SqlSession

MyBatis还提供了一个MyBatisTemplate类,会将SqlSession交由Spring管理。我们只要声明该对象,并注入到代码中使用即可。

<!--MyBatis的SqlSession模板,封装了SqlSession-->
<bean id="sqlSessionTemplate"
      class="org.mybatis.spring.SqlSessionTemplate">
    <constructor-arg type="org.apache.ibatis.session.SqlSessionFactory"
                     ref="sqlSessionFactory"/>
</bean>

或者还可以继承SqlSessionDaoSupport类,它提供了getSqlSession()方法,可以直接获取当前由Spring管理的SqlSession。

注入映射器

MyBatis的映射器可以通过MapperFactoryBean工厂类来注册。注册之后,我们就可以直接注入到DAO中使用,连MyBatisTemplate都免了。

<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
  <property name="mapperInterface" value="org.mybatis.spring.sample.mapper.UserMapper" />
  <property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>

如果有多个映射器的话,我们甚至可以利用MyBatis提供的命名空间直接扫描所有映射器。

<!--自动搜索Mapper-->
<mybatis:scan base-package="yitian.study.mapper"/>

然后我们的代码就变得非常干净。

@Repository
public class AuthorDaoImpl implements AuthorDao {
    private SqlSessionTemplate template;
    private MultiMapper mapper;

    @Autowired
    public AuthorDaoImpl(SqlSessionTemplate template, MultiMapper mapper) {
        this.template = template;//模板对象甚至都没使用
        this.mapper = mapper;
    }

    @Override
    public void add(Author author) {
        mapper.insertAuthor(author);
    }

    @Override
    public Author getById(int id) {
        return mapper.selectAuthorById(id);
    }

    @Override
    public Author getByName(String username) {
        return mapper.selectAuthorByName(username);
    }

    @Override
    public void update(Author author) {
        mapper.updateAuthor(author);
    }

    @Override
    public void delete(Author author) {
        mapper.deleteAuthor(author);
    }
}

封装异常

Spring可以将Hibernate、JPA等不同技术的异常,统一封装为Spring自己的异常层次。这样我们就能在Spring程序中统一处理异常了。

首先我们的DAO类需要@Repository注解。

@Repository
public class AuthorDaoImpl implements AuthorDao {
    private SqlSessionTemplate template;
    private MultiMapper mapper;

    @Autowired
    public AuthorDaoImpl(SqlSessionTemplate template, MultiMapper mapper) {
        this.template = template;
        this.mapper = mapper;
    }
    //其他代码省略了
}

然后我们需要声明下面两个Spring Bean。

<!--异常拦截器,用于将MyBatis封装为Spring异常-->
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>
<bean class="org.mybatis.spring.MyBatisExceptionTranslator">
    <constructor-arg type="javax.sql.DataSource" ref="dataSource"/>
    <constructor-arg type="boolean" value="false"/>
</bean>

这样代码中抛出的JDBC异常都会被翻译成Spring的异常。由于Spring中可以对@Repository注解的类进行常见JDBC异常的封装,所以即使没有上面的声明,我们得到的异常也是Spring的DataAccessException。一开始我以为Spring没有进行异常转换,后来我发现原来由于Spring贴心的打印了原异常,把我搞晕了。如果捕获异常然后查看一下异常类型,就会发现已经是Spring的异常了。

参考资料

MyBatis-Spring文档

相关文章
|
21天前
|
XML Java API
Spring Boot集成MinIO
本文介绍了如何在Spring Boot项目中集成MinIO,一个高性能的分布式对象存储服务。主要步骤包括:引入MinIO依赖、配置MinIO属性、创建MinIO配置类和服务类、使用服务类实现文件上传和下载功能,以及运行应用进行测试。通过这些步骤,可以轻松地在项目中使用MinIO的对象存储功能。
|
22天前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
36 4
|
23天前
|
消息中间件 Java Kafka
什么是Apache Kafka?如何将其与Spring Boot集成?
什么是Apache Kafka?如何将其与Spring Boot集成?
58 5
|
22天前
|
SQL Java 数据库连接
spring和Mybatis的各种查询
Spring 和 MyBatis 的结合使得数据访问层的开发变得更加简洁和高效。通过以上各种查询操作的详细讲解,我们可以看到 MyBatis 在处理简单查询、条件查询、分页查询、联合查询和动态 SQL 查询方面的强大功能。熟练掌握这些操作,可以极大提升开发效率和代码质量。
34 3
|
25天前
|
消息中间件 Java Kafka
Spring Boot 与 Apache Kafka 集成详解:构建高效消息驱动应用
Spring Boot 与 Apache Kafka 集成详解:构建高效消息驱动应用
37 1
|
27天前
|
Java 数据库连接 数据库
spring和Mybatis的逆向工程
通过本文的介绍,我们了解了如何使用Spring和MyBatis进行逆向工程,包括环境配置、MyBatis Generator配置、Spring和MyBatis整合以及业务逻辑的编写。逆向工程极大地提高了开发效率,减少了重复劳动,保证了代码的一致性和可维护性。希望这篇文章能帮助你在项目中高效地使用Spring和MyBatis。
17 1
|
1月前
|
SQL Java 数据库连接
MyBatis-Plus快速入门:从安装到第一个Demo
本文将带你从零开始,快速入门 MyBatis-Plus。我们将首先介绍如何安装和配置 MyBatis-Plus,然后通过一个简单的示例演示如何使用它进行数据操作。无论你是 MyBatis 的新手还是希望提升开发效率的老手,本文都将为你提供清晰的指导和实用的技巧。
407 0
MyBatis-Plus快速入门:从安装到第一个Demo
|
2月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
521 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
2月前
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
203 1
|
2月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
222 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库