SpringBoot踩坑记录(1)Invalid bound statement (not found)引发的一些列问题

SpringBoot踩坑记录(1)

Invalid bound statement (not found)引发的一些列问题

当你开开心心搭建了一个SpringBoot项目,用插件生成了entity、dao、mapper,写下第一个Controller准备试一下,结果却发现一条简单的查询报错了。 

{
        "timestamp": "2019-03-18 16:21:48",
        "status": 500,
        "error": "Internal Server Error",
        "message": "Invalid bound statement (not found): com.xxx.dao.UserMapper.selectByPrimaryKey",
        "path": "/test"
    }

经过排查,发现target/classes/包名目录下不存在mapper文件夹,一个令人伤心的事情。

        于是我们知道了关键所在,怎么把mapper下的xml文件打包进去。通过查阅资料,我们知道了解决这个问题通常有两个思路:

1.将mapper放在src/main/resource 目录下,这个目录下默认是会打包进去的。

2.在pom文件的

<build>
</build>

节点内,添加一段

<resources>
   <resource>
      <directory>src/main/java</directory>
      <includes>
         <include>**/*.xml</include>
      </includes>
      <!-- 是否替换资源中的属性-->
      <filtering>false</filtering>
   </resource>
</resources>

 3.当你打包时,手动把xml文件所在的mapper文件夹丢进target/classes/包名/目录下。需要丢一次+运行一次就好了

以上3种方法我只试过下面两种,上面那种虽然没有确切放过xml文件,但是其他类文件的存放以及打包倒是用过,这个后面再说。

现在来确切说说第二种。这里是有坑的

坑.1 配置过度导致捡了芝麻丢了西瓜

比如,会在别处看到一些这样的配置。实际上src/main/resources下的文件都会被打包,如果把图中那段注释解开,你会发现除了xml和properties文件,其他东西都没打包进去(如果你使用的是yml配置,那么yml也不会被打包进去),图中的这位博主估计也是发现了这段代码的弊大于利,233.

这里就牵扯出一个问题了。如果我的项目中resource下只有xml,和properties文件,这段配置也无伤大雅咯?是的,的确是这样,templates和static下似乎是能打包进去的。

 

在解决了xml打包之后,我们迫不及待的继续打包运行,发现依旧是那个报错,emmmmmmm,这让人不禁有些头大。翻开前辈的项目,发现了在yml下,还配置了mybatis

mybatis:
  mapper-locations: classpath:com/xx/xxx/mapper/**/*.xml
  type-aliases-package: com.xx.xxx.entity
  configuration:
    cache-enabled: false

很好,粘过来改成我们的包名,应该能解决了 

坑.2 Mybatis路径配置须小心

 当看到路径里mapper/**/*.xml时,不知怎么的,我就自作聪明把mapper给删掉了,/**/*.xml,看似是指向下一级目录的xml文件,但是当你自作聪明的删掉了这里之后,你会发现xml虽然打包进去了,但是你的dao依然找不到mapper,还是报错。

血的教训啊,童鞋们切记这个路径是:包名/xml所在目录/**/*.xml

 

 

暂时写到这里,下次有空再更

SpringBoot整合Mybatis时,出现"Invalid bound statement (not found)"这个问题的实质是mapper接口和mapper.xml没有正确地映射起来。 为了解决这个问题,你可以按照以下步骤进行操作: 1. 首先,确认你的mapper接口和mapper.xml文件位于正确的位置,并且它们的命名规范是一致的。通常情况下,mapper接口应该位于`com.smbms.mybatis.mapper`包下,而mapper.xml文件应该位于`resources/mapper`目录下。 2. 确保在主配置文件(即application.properties或application.yml)中添加了正确的配置。根据引用中的代码示例,你需要在application.properties文件中添加如下配置: ``` mybatis.typeAliasesPackage=com.smbms.mybatis.popj mybatis.mapperLocations=classpath:mapper/*.xml ``` 这样配置后,Mybatis就能正确地找到mapper.xml文件并与mapper接口进行映射。 3. 最后,重新编译和运行你的项目,确保没有其他错误导致该问题。如果问题仍然存在,可以检查一下mapper接口中的方法名和mapper.xml文件中的SQL语句是否一致,另外也可以尝试重新生成mapper接口和mapper.xml文件。 通过以上的步骤,你应该能够解决"Invalid bound statement (not found)"的问题,并成功实现SpringBoot与Mybatis的整合。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [springboot整合mybatis出现Invalid bound statement (not found)](https://blog.csdn.net/weixin_56044831/article/details/116863995)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot整合mybatis时报Invalid bound statement (not found)错误的可能原因](https://blog.csdn.net/wsaicyj/article/details/124286481)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值