【spring boot】mybatis启动报错:Consider defining a bean of type 'com.newhope.interview.dao.UserMapper' in your configuration. 【Mapper类不能被找到】@Mapper 和@MapperScan注解的区别

摘要:
==========================================至于@Mapper和@MapperScan注释之间的区别,一个只需要在启动类中配置一次,另一个需要在每个映射器上配置

启动报错:

2018-05-16 17:22:58.161 ERROR 4080 --- Disconnected from the target VM, address: '127.0.0.1:50529', transport: 'socket'
[  restartedMain] o.s.b.d.LoggingFailureAnalysisReporter   : 

***************************
APPLICATION FAILED TO START
***************************

Description:

Field huaYangAreaMapper in com.sxd.swapping.service.impl.HuaYangServiceImpl required a bean of type 'com.sxd.swapping.dao.mybatis.HuaYangAreaMapper' that could not be found.


Action:

Consider defining a bean of type 'com.sxd.swapping.dao.mybatis.HuaYangAreaMapper' in your configuration.

解决方案:

根据错误提示

Mybatis的 Mapper类不能被找到,所以需要通过注解标明这个类可以给spring 管理并且给其他类调用的。

下面有两种方式提供:

方式1:使用@Mapper注解标注在Mapper类上

@Mapper
public interface HuaYangAreaMapper {

    @Select("SELECT * FROM hua_yang_area where uid = #{uid}")
    @Results({
            @Result(property = "areaName",column = "area_name",javaType = String.class),
            @Result(property = "areaPerson",column = "area_person",javaType = Long.class),
            @Result(property = "createId",column = "create_id",javaType = String.class)
    })
    HuaYangArea findOne(String uid);


}

方式2:使用@MapperScan("mapper类所在包位置")

@SpringBootApplication
@MapperScan("com.sxd.swapping.dao.mybatis")
public class SwappingApplication {

    public static void main(String[] args) {
        SpringApplication.run(SwappingApplication.class, args);
    }
}

如果有多个包需要被扫描到,可以传入字符串数组

@MapperScan({"com.sxd.swapping.dao.mybatis","com.sxd.swapping.dao.mapper"})

上面这两种方式都可以使用。

====================================

至于@Mapper 和@MapperScan注解的区别,一个只需要在启动类配置一次,一个是需要在每个mapper上进行配置

免责声明:文章转载自《【spring boot】mybatis启动报错:Consider defining a bean of type 'com.newhope.interview.dao.UserMapper' in your configuration. 【Mapper类不能被找到】@Mapper 和@MapperScan注解的区别》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇【postman】安装使用说明【hibernate/JPA】注解方式实现 复合主键【spring boot】下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

SpringBoot集成Mybatis 【企业应用专题】

SpringBoot集成Mybatis 一、导入依赖(pom文件) <!--Mybatis-Plus--><dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</a...

【转修正】sql server行版本控制的隔离级别

在SQL Server标准的已提交读(READ COMMITTED)隔离级别下,一个读操作会和一个写操作相互阻塞。未提交读(READ UNCOMMITTED)虽然不会有这种阻塞,但是读操作可能会读到脏数据,这是大部分用户不能接受的。有些关系型数据库(例如Oracle)使用的是另一种处理方式。在任何一个修改之前,先对修改前的版本做一个复制[WX1],后续的一切...

MySQL和Oracle的区别

语言的分类: MySQL中语言的分类:数据定义语言(DDL):drop,create,alter等语句 数据操作语言(DML):insert,update,delete 数据查询语言(DQL):select等语句 数据控制语言(DCL):gra...

jQuery 使用注意点技巧1

1、$函数的使用技巧和注意点 <div value="content">aaa</div> $("#msg").value的写法是错误的,因为: 通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用dom定义的方...

MySQL入门(一)

1. MySQL是什么? MySQL是一个小型的关系型数据库管理系统,开发者为瑞典MySQL AB 公司,在2008年1月16号被sun公司收购,之后又在2009年4月被Oracle公司收购,现属于Oracle旗下产品。 MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的RDBMS(Relational Datab...

.Net程序员学用Oracle系列(3):数据库编程规范

1、书写规范 1.1、大小写风格 1.2、缩进风格 1.3、换行 1.4、其它 2、命名规范 2.1、数据库对象命名 2.2、变量命名 3、注释规范 4、语法规范 5、总结 5.1、代码的可读性比说明文档更重要 5.2、编程规范必不可少 作为一名使用 Oracle 的开发人员,在写这个系列博文之前,我原打算仅对常用...