SpringBoot集成Mybatis

前言

SpringBoot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。
SpringBoot中,如果需要访问数据库,只需要引入spring-boot-starter-data-jpa这个starter即可。这个starter默认引入的ormhibernatehibernate自然有其自身的优缺点,这里不做讨论。本文讨论的是如何在SpringBoot环境中引入mybatis

pom.xml

如果需要使用mybatis,只需要引入mybatis-spring-boot-starter即可,如下:

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.2.0</version>
        </dependency>

相关的mybatismybatis-springmybatis-spring-boot-autofigure等都会被引入。
到这里,mybatis的集成工作基本就完成了。spring默认会扫描@mapper注解的接口并实例化为mapper,并通过环境变量mybatis.mapper-locations的值确定包含mapper的xml文件的路径。

控制@mapper注解的扫描包路径

在你的@SpringBootApplication注解的类上添加如下注解即可:

@MapperScan(value = "com.xxx.xxx", annotationClass = Mapper.class)

SpringBoot启动后,会扫描此包下所有的包含@mapper的接口(或类?),并实例化,如果你想指定实例化对象的名字,可通过如下注解:

@Repository("xxxXXXX")

这样如果需要注入此对象,可使用@Resource(name = "xxxXXXX")注解.

控制包含mapper的xml文件的路径

SpringBoot会扫描环境变量mybatis.mapper-locations值所指向的路径,例如classpath:db/mapper/**/*.xml,此值可以通过多种方式指定。

  • 通过环境变量指定System.setProperty("mybatis.mapper-locations", "classpath:db/mapper/**/*.xml");
  • 通过application.properties文件指定mybatis.mapper-locations=classpath:db/mapper/**/*.xml

多说一句

mybatis支持通过@mapper注解或xml文件来实例化mapp对象,两种方式各有其优缺点。我个人比较倾向于使用注解的方式,因为使用注解来编程器效率是十分高效的,且代码后期的维护也较为容易。不过由于目前xml的一些功能使用注解还不能实现,因此推荐xml文件和注解两种方式混用。具体方式就是使用mybatis-generator来生成固定的包含mapper的xml文件;使用注解来编写需要自定义的mapper接口文件(在接口文件中可以使用@select@update等注解)。

mybatis分页及拦截器的配置将在后续文章中继续。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值