• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    详解 MapperScannerConfigurer之sqlSessionFactory注入方式

    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 .

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

    您可能感兴趣的文章:
    • MyBatis直接执行SQL的工具SqlMapper
    • Mybatis中SqlMapper配置的扩展与应用详细介绍(1)
    • 使用XSD校验Mybatis的SqlMapper配置文件的方法(2)
    • 使用XSD校验Mybatis的SqlMapper配置文件的方法(1)
    • 详解MyBatis的getMapper()接口、resultMap标签、Alias别名、 尽量提取sql列、动态操作
    • MyBatis MapperProvider MessageFormat拼接批量SQL语句执行报错的原因分析及解决办法
    • Mapper sql语句字段和实体类属性名字有什么关系
    上一篇:MySQL与Oracle SQL语言差异比较一览
    下一篇:常用SQL语句优化技巧总结【经典】
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    详解 MapperScannerConfigurer之sqlSessionFactory注入方式 详解,MapperScannerConfigurer,