• MyBatis-Plus找不到Mapper.xml文件的解决方法


    在整合SpringBoot和Mybatis-plus时,想写自定义的sql,所以创建了Mapper.xml文件,但是启动后却老是报错:

    org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

    很明显,是Mapper.xml未被扫描到。

    此类问题的解决方式实际上都是配置上有问题,以下列出了一些解决方式。

    **方式1:**Mapper的命名空间和Dao层的接口。

    Mapper.xml文件中,

    **方式2:**如果Mapper.xml文件是放到java目录下,那么在项目的pom.xml文件中需要添加:

    src/main/java \*\*/\*.xml

    **方式3:**注意在.yml配置文件中不要弄混淆Mybatis和Mybatis-plus的配置

    比如项目pom.xml中引用的是Mybatis-plus的starter,其中已经包含了Mybatis了,配置文件中最好统一写成Mybatis-plus的配置:

    mybatis:

    mapper-locations: classpath:com/*/mapper/xml/*.xml

    改成

    mybatis-plus:

    mapper-locations: classpath:com/*/mapper/xml/*.xml

    **方式4:**如果是多子模块的项目,Mapper.xml文件是在子模块项目中,那么记得在classpath后面加*,代表扫描子项目的Mapper.xml文件

    mybatis-plus:

    mapper-locations: classpath*:com/*/mapper/xml/*.xml

    **方式5:**我最近放的一个小错误,就是我的Mapper.xml文件是放在不同层次不同包下的,我配置了很多个扫描位置:

    mybatis-plus:

    mapper-locations: classpath*:com/*/mapper/xml/*.xml,com/test/*/mapper/xml/*.xml,/xml/*.xml

    配置好发现依然报未扫描到Mapper.xml文件,后来发现,我的Mapper.xml文件是放到子模块中的"com/test/*/mapper/xml"目录下,配置应该要继续带上classpath*:

    上面的配置改成:

    mybatis-plus:

    mapper-locations: classpath*:com/*/mapper/xml/*.xml,classpath*:com/test/*/mapper/xml/*.xml,/xml/*.xml

    因为路径前面不带这个"classpath*“它默认是使用的"classpath”,导致扫描不到子模块项目的Mapper.xml文件。

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    3.1、前端异步编程(超详细手写实现Promise;实现all、race、allSettled、any;async/await的使用)
    Qt中 QMap 类、QHash 类、QVector 类详解
    了解方法重写
    介绍一款高性能分布式MQTT Broker(带web)
    ResNet18-实现图像分类
    Lanbda表达式
    Flask 学习-33.restful-full 请求参数校验reqparse.RequestParser()
    Java设计模式三—— 策略模式、工厂模式
    C# - Entity Framework 对一个或多个实体的验证失败。有关详细信息,请参阅“EntityValidationErrors”属性
    云原生-FRP内网穿透(详解)使用云服务器将内网集群服务暴露至公网(二)
  • 原文地址:https://blog.csdn.net/m0_54850825/article/details/126112871