问题一:MVC架构中,启动类使用@SpringBootApplication注解,无法识别mapper类。
解决方案:在启动类添加@MapperScan注解,扫描mapper类所在的包。
注意:这里要注意在使用@MapperScan注解时,在pom文件中添加的依赖不是mybatis-spring这个依赖,而是mybatis-spring-boot-starter这个依赖。如果用了错误的依赖,会报错:
java.lang.annotation.AnnotationFormatError: Invalid default: public abstract java.lang.Class org.mybatis.spring.annotation.MapperScan.factoryBean()
正确的引用是:
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.3</version>
</dependency>
idea默认的引用可能会发生错误,若未给到正确的依赖,则手动删除原依赖更新至这一依赖即可。
问题二:mysql数据库中字段使用了下划线,与实体类中带有下划线的字段无法匹配。
解决方案:在java中使用驼峰命名方式,并通过mybatis的驼峰命名转换,实现驼峰命名和下划线的匹配。mybatis的驼峰命名转换需要在properties文件中配置:
mybatis.configuration.map-underscore-to-camel-case=true
或在yaml文件中配置:
mybatis:
configuration:
map-underscore-to-camel-case: true