专栏名称: ImportNew
伯乐在线旗下账号,专注Java技术分享,包括Java基础技术、进阶技能、架构设计和Java技术领域动态等。
目录
相关文章推荐
芋道源码  ·  如何设计一个全局唯一的订单号? ·  2 天前  
芋道源码  ·  再见ExecutorService,你好St ... ·  4 天前  
芋道源码  ·  SkyWalking VS ELK ... ·  6 天前  
芋道源码  ·  K 神!国产神级搜索引擎~太强了? ·  6 天前  
51好读  ›  专栏  ›  ImportNew

MyBatis 快速入门(4):MyBatis 和 Spring 集成

ImportNew  · 公众号  · Java  · 2017-03-25 20:03

正文

(点击上方公众号,可快速关注)


来源:乐百川,

www.jianshu.com/p/2137fcce6f3c

如有好文章投稿,请点击 → 这里了解详情


导入依赖包


前面介绍了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配置文件。


      class="org.mybatis.spring.SqlSessionFactoryBean">

   

   

      class="com.mysql.jdbc.jdbc2.optional.MysqlConnectionPoolDataSource">

   

   

   

   


事务管理


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


      class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

   

           transaction-manager="transactionManager">

   

       

       

   

   

                  expression="execution(* yitian.study.dao.*.*(..))"/>

   


使用SqlSession


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


      class="org.mybatis.spring.SqlSessionTemplate">

   

                     ref="sqlSessionFactory"/>


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


注入映射器


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


 

 


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



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


@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。


   

   


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


参考资料


  • MyBatis-Spring文档

    http://www.mybatis.org/spring/index.html


本系列:



看完本文有收获?请转发分享给更多人

关注「ImportNew」,看技术干货