当前位置:   article > 正文

【吊打面试官系列-MyBatis面试题】Mapper 编写有哪几种方式?

【吊打面试官系列-MyBatis面试题】Mapper 编写有哪几种方式?

大家好,我是锋哥。今天分享关于 【Mapper 编写有哪几种方式?】面试题,希望对大家有帮助;

Mapper 编写有哪几种方式?

第一种:接口实现类继承 SqlSessionDaoSupport:使用此种方法需要编写
mapper 接口,mapper 接口实现类、mapper.xml 文件。
1、在 sqlMapConfig.xml 中配置 mapper.xml 的位置
  1. <mappers>
  2. <mapper resource="mapper.xml 文件的地址" />
  3. <mapper resource="mapper.xml 文件的地址" />
  4. </mappers>
1、定义 mapper 接口
3、实现类集成 SqlSessionDaoSupport
mapper 方法中可以 this.getSqlSession()进行数据增删改查。
4、spring 配置
  1. <bean id=" " class="mapper 接口的实现">
  2. <property name="sqlSessionFactory"
  3. ref="sqlSessionFactory"></property>
  4. </bean>
第二种:使用 org.mybatis.spring.mapper.MapperFactoryBean
1、在 sqlMapConfig.xml 中配置 mapper.xml 的位置,如果 mapper.xml 和 mappre 接口的名称相同且在同一个目录,这里可以不用配置
  1. <mappers>
  2. <mapper resource="mapper.xml 文件的地址" />
  3. <mapper resource="mapper.xml 文件的地址" />
  4. </mappers>
2、定义 mapper 接口:
1、mapper.xml 中的 namespace 为 mapper 接口的地址
2、mapper 接口中的方法名和 mapper.xml 中的定义的 statement 的 id 保持一
3、Spring 中定义
  1. <bean id="" class="org.mybatis.spring.mapper.MapperFactoryBean">
  2. <property name="mapperInterface" value="mapper 接口地址" />
  3. <property name="sqlSessionFactory" ref="sqlSessionFactory" />
  4. </bean>
第三种:使用 mapper 扫描器:
1、mapper.xml 文件编写:
mapper.xml 中的 namespace 为 mapper 接口的地址;
mapper 接口中的方法名和 mapper.xml 中的定义的 statement 的 id 保持一致;
如果将 mapper.xml 和 mapper 接口的名称保持一致则不用在 sqlMapConfig.xml
中进行配置。
2、定义 mapper 接口:
注意 mapper.xml 的文件名和 mapper 的接口名称保持一致,且放在同一个目录
3、配置 mapper 扫描器:
  1. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  2. <property name="basePackage" value="mapper 接口包地址
  3. "></property>
  4. <property name="sqlSessionFactoryBeanName"
  5. value="sqlSessionFactory"/>
  6. </bean>
4、使用扫描器后从 spring 容器中获取 mapper 的实现对象。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/煮酒与君饮/article/detail/830777
推荐阅读
相关标签
  

闽ICP备14008679号