当前位置: 移动技术网 > IT编程>数据库>其他数据库 > 详解 MapperScannerConfigurer之sqlSessionFactory注入方式

详解 MapperScannerConfigurer之sqlSessionFactory注入方式

2017年12月01日  | 移动技术网IT编程  | 我要评论
mapperscannerconfigurer之sqlsessionfactory注入方式讲解 首先,mybatis中的有一段配置非常方便,省去我们去写daoimpl(d

mapperscannerconfigurer之sqlsessionfactory注入方式讲解

首先,mybatis中的有一段配置非常方便,省去我们去写daoimpl(dao层实现类)的时间,这个配置就是包扫描。。。。

让我们先来看一段代码:

  <!-- 4:配置扫描dao接口的包,动态实现dao接口,注入到spring容器中 -->
  <bean class="org.mybatis.spring.mapper.mapperscannerconfigurer">
    <!--这里是今天要说的重点-->
    <property name="sqlsessionfactorybeanname" value="sqlsessionfactory"></property>
    <!-- 给出需要扫描的dao接口包 -->
    <property name="basepackage" value="org.seckill.dao"></property>
  </bean>

在mapperscannerconfigurer中,我们知道sqlsessionfactory的注入方式有四种,分别是sqlsessionfactory,sqlsessionfactorybeanname,sqlsessiontemplate,sqlsessiontemplatebeanname,而sqlsessionfactory这种已经过时,所以我们用到的是sqlsessionfactorybeanname,接下来说说这个的好处,为什么要用到它!

原因1:

注入sqlsessionfactory,(可以不用配置)只有当配置多数据源的时候,这时会有多个sqlsessionfactory,可以通过改属性来指定哪一个sqlsessionfactory(综合网上的总结)

原因2(重点):

注入sqlsessionfactory,后面的value是sqlsessionfactory的bean的名字,也就是sqlsessionfactory的id当我们的mapperscannerconfigurer启动的时候,可能会出现我们的jdbc.properties文件未被加载,这样的话它拿到的datasource就是错误的,因为像${jdbc.url}这类的属性还没有被替换掉,所以通过beanname后处理的方式,当我们去用我们的mybatis的时候,它才会去找我们对应的sqlsessionfactory,为了防止它提前初始化我们的sqlsessionfactory .

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网