解決java中mybatis報(bào)錯(cuò):org.apache.ibatis.binding.BindingException:Invalid bound statement(not found):xx問(wèn)題
報(bào)錯(cuò)信息
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): springtransactionaldemo.demo.mapper.UserMapper.selectAll at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) ~[mybatis-3.5.9.jar:3.5.9] at org.apache.ibatis.binding.MapperMethod.<init>(MapperMethod.java:53) ~[mybatis-3.5.9.jar:3.5.9] at org.apache.ibatis.binding.MapperProxy.lambda$cachedInvoker$0(MapperProxy.java:108) ......
代碼如下
- UserController
/**
* Created By 李柏霖
* 2024/1/13 23:01
*/
package springtransactionaldemo.demo.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import springtransactionaldemo.demo.pojo.User;
import springtransactionaldemo.demo.service.IUserService;
import java.util.List;
@Controller
public class UserController {
@Autowired
private IUserService userService;
@GetMapping("/getAllUsers")
@ResponseBody
public List<User> getAllUsers() {
List<User> users = userService.selectAllUsers();
System.out.println(users);
return users;
}
}
- IUserService
/**
* Created By 李柏霖
* 2024/1/13 22:24
*/
package springtransactionaldemo.demo.service;
import springtransactionaldemo.demo.pojo.User;
import java.util.List;
public interface IUserService {
List<User> selectAllUsers();
}
- IUserServiceImpl
/**
* Created By 李柏霖
* 2024/1/13 22:25
*/
package springtransactionaldemo.demo.service.Impl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import springtransactionaldemo.demo.mapper.UserMapper;
import springtransactionaldemo.demo.pojo.User;
import springtransactionaldemo.demo.service.IUserService;
import java.util.List;
@Service
public class IUserServiceImpl implements IUserService {
@Autowired
private UserMapper userMapper;
@Override
@Transactional
public List<User> selectAllUsers() {
return userMapper.selectAll();
}
}
- UserMapper
/**
* Created By 李柏霖
* 2024/1/13 22:22
*/
package springtransactionaldemo.demo.mapper;
import org.apache.ibatis.annotations.Mapper;
import springtransactionaldemo.demo.pojo.User;
import java.util.List;
@Mapper
public interface UserMapper {
List<User> selectAll();
}
- UserMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="springtransactionaldemo.demo.mapper.UserMapper">
<!-- MyBatis 映射文件 -->
<select id="selectAll" resultType="springtransactionaldemo.demo.pojo.User">
SELECT * FROM user
</select>
</mapper>
- DemoApplication
package springtransactionaldemo.demo;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.transaction.annotation.EnableTransactionManagement;
@SpringBootApplication
@EnableTransactionManagement
@MapperScan("springtransactionaldemo.demo.mapper")
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
解決辦法
在 application.properties文件中添加以下配置:
mybatis.mapper-locations=classpath:mapper/*.xml

拓展
上述代碼中即在DemoApplication中添加了@MapperScan注解,又在UserMapper類(lèi)中添加了@Mapper注解。
其實(shí)這兩個(gè)只需要加一個(gè)即可。
我這邊習(xí)慣全加了
代碼運(yùn)行展示:


總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 解決mybatis plus報(bào)錯(cuò)Invalid bound statement (not found):問(wèn)題
- mybatis Invalid bound statement(not found)排坑記錄
- SpringBoot報(bào)錯(cuò)Invalid?bound?statement?(not?found)問(wèn)題排查和解決方案
- mybatis整合springboot報(bào)BindingException:Invalid?bound?statement?(not?found)異常解決
- Invalid bound statement(not found):錯(cuò)誤的解決方案
相關(guān)文章
SpringBoot整合JPA數(shù)據(jù)源方法及配置解析
這篇文章主要介紹了SpringBoot整合JPA數(shù)據(jù)源方法及配置解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
Java后端SSM框架圖片上傳功能實(shí)現(xiàn)方法解析
這篇文章主要介紹了Java后端SSM框架圖片上傳功能實(shí)現(xiàn)方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
使用MyBatis 動(dòng)態(tài)update數(shù)據(jù)
使用mybatis寫(xiě)sql,需要?jiǎng)討B(tài)更新對(duì)象數(shù)據(jù),每次需要更新的字段不同,為了防止null空異常,就需要用動(dòng)態(tài)sql了,下面給大家分享一段代碼關(guān)于mybatis動(dòng)態(tài)update,需要的朋友參考下2016-11-11
Java判斷中英文符號(hào)、標(biāo)點(diǎn)的實(shí)現(xiàn)
本篇文章主要介紹了Java判斷中英文符號(hào)、標(biāo)點(diǎn)的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
java實(shí)現(xiàn)自定義日期選擇器的方法實(shí)例
日期選擇器是我們?nèi)粘i_(kāi)發(fā)中經(jīng)常需要用到的一個(gè)功能,下面這篇文章主要給大家介紹了關(guān)于利用java實(shí)現(xiàn)自定義日期選擇器的相關(guān)資料,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10
java 將jsonarray 轉(zhuǎn)化為對(duì)應(yīng)鍵值的jsonobject方法
下面小編就為大家分享一篇java 將jsonarray 轉(zhuǎn)化為對(duì)應(yīng)鍵值的jsonobject方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
基于springboot+vue實(shí)現(xiàn)垃圾分類(lèi)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于springboot+vue實(shí)現(xiàn)垃圾分類(lèi)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07

