激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 詳解mybatis-plus的 mapper.xml 路徑配置的坑

詳解mybatis-plus的 mapper.xml 路徑配置的坑

2020-08-26 00:14一只倔強的碼蟻 Java教程

這篇文章主要介紹了詳解mybatis-plus的 mapper.xml 路徑配置的坑,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

mybatis-plus今天遇到一個問題,就是mybatis 沒有讀取到mapper.xml 文件。

特此記錄一下,問題如下:

?
1
2
3
4
5
6
7
8
9
10
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.husy.mapper.SystemUserMapper.findUserByName
 
    at com.baomidou.mybatisplus.core.override.MybatisMapperMethod$SqlCommand.<init>(MybatisMapperMethod.java:242)
    at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:54)
    at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedMapperMethod$0(MybatisMapperProxy.java:65)
    at java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1660)
    at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedMapperMethod(MybatisMapperProxy.java:65)
    at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:60)
    at com.sun.proxy.$Proxy72.findUserByName(Unknown Source)
    at com.husy.service.impl.SystemUserServiceImpl.findUserByName(SystemUserServiceImpl.java:23)

錯誤代碼如下:

mapper.xml 目錄

詳解mybatis-plus的 mapper.xml 路徑配置的坑

代碼如下:

單元測試

?
1
2
3
4
5
@Test
public void findUser(){
    SystemUser systemUser= systemUserService.findUserByName("admin");
    System.out.println(systemUser.toString());
}

mybatis-puls 配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@EnableTransactionManagement
@Configuration
@MapperScan("com.husy.mapper")
public class MybatisConfig {
 
  /**
   * mybatis-plus 分頁插件
   */
  @Bean
  public PaginationInterceptor paginationInterceptor() {
    return new PaginationInterceptor();
  }
}

service實現

?
1
2
3
4
5
6
7
8
9
10
@Service
public class SystemUserServiceImpl implements SystemUserService {
    @Autowired
    private SystemUserMapper userMapper;
 
    @Override
    public SystemUser findUserByName(String name) {
        return userMapper.findUserByName(name);
    }
}

mapper 接口

?
1
2
3
4
@Component
public interface SystemUserMapper {
    SystemUser findUserByName(@Param("userAccount") String name);
}

mapper.xml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?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="com.husy.mapper.SystemUserMapper">
  <resultMap id="systemUserMap" type="com.husy.domain.SystemUser" >
    <id column="user_id" property="userId" />
    <result column="user_account" property="userAccount" />
    <result column="user_password" property="userPassword" />
    <result column="user_phone" property="userPhone" />
  </resultMap>
  <select id="findUserByName" resultMap="systemUserMap">
     SELECT
      user_id,
      user_account,
      user_password,
      user_phone
     FROM t_system_user
     where user_account = #{userAccount}
  </select>
</mapper>

通過上面的代碼可以看出。mapper接口中的方法和映射文件中的方法名稱是一樣的。不存在名稱錯誤導致的情況,返回值,參數類型等你都正確。如果找不到方法,那一定是映射文件配置問題,只有沒有讀取到,才會出現找不到的情況。
我的配置如下:

問題出錯的關鍵位置

我這里引用的是 mybatis-plus-boot-starte 依賴

?
1
2
3
4
5
<dependency>
  <groupId>com.baomidou</groupId>
   <artifactId>mybatis-plus-boot-starter</artifactId>
   <version>3.1.0</version>
 </dependency>

mapper.xml 的文件引用路徑配置如下:

?
1
mybatis.mapper-locations=classpath:mapper/*.xml

這就導致,mybatis 讀取不到 mapper映射文件。

經過查閱:

  • 如果引用mybatis-plus-boot-starter 依賴,需要配置 mybatis-plus.mapper-locations
  • 如果引用mybatis-plus 依賴,需要配置 mybatis.mapper-locations

如下:

引用 mybatis-plus 包

?
1
2
3
4
5
<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-plus</artifactId>
  <version>3.1.0</version>
</dependency>
?
1
mybatis.mapper-locations=classpath:mapper/*.xml

引用 mybatis-plus-boot-starter 包

?
1
2
3
4
5
<dependency>
   <groupId>com.baomidou</groupId>
   <artifactId>mybatis-plus-boot-starter</artifactId>
   <version>3.1.0</version>
 </dependency>
?
1
mybatis-plus.mapper-locations=classpath:mapper/*.xml

只要選用其中一種方式,就沒有問題了。

今天看到評論區有小伙伴說沒有作用,這里給了一份Demo ,有問題的小伙伴可以比對一下。

POM

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.2.2.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
  </parent>
  <groupId>com.example</groupId>
  <artifactId>demo</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <name>demo</name>
  <description>Demo project for Spring Boot</description>
 
  <properties>
    <java.version>1.8</java.version>
  </properties>
 
  <dependencies>
    <dependency>
      <groupId>org.mybatis.spring.boot</groupId>
      <artifactId>mybatis-spring-boot-starter</artifactId>
      <version>2.1.1</version>
    </dependency>
 
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <scope>runtime</scope>
    </dependency>
    <dependency>
      <groupId>com.baomidou</groupId>
      <artifactId>mybatis-plus-boot-starter</artifactId>
      <version>3.3.0</version>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-test</artifactId>
      <scope>test</scope>
      <exclusions>
        <exclusion>
          <groupId>org.junit.vintage</groupId>
          <artifactId>junit-vintage-engine</artifactId>
        </exclusion>
      </exclusions>
    </dependency>
  </dependencies>
 
  <build>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
    </plugins>
  </build>
 
</project>

application.properties

?
1
2
3
4
5
6
7
# DataSource Config
spring.datasource.url=jdbc:mysql://localhost:3306/db_husy?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=GMT%2B8&zeroDateTimeBehavior=CONVERT_TO_NULL
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
 
mybatis-plus.mapper-locations=classpath:/mapper/*.xml

MybatisConfig

?
1
2
3
4
5
6
7
8
9
10
@EnableTransactionManagement
@Configuration
@MapperScan("com.example.demo.mapper")
public class MybatisConfig {
    /**mybatis-plus 分頁插件*/
    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }
}

其他文件基本沒變化。附上目錄

詳解mybatis-plus的 mapper.xml 路徑配置的坑

單元測試

?
1
2
3
4
5
6
7
8
9
10
11
@SpringBootTest
class DemoApplicationTests {
    @Autowired
    SystemUserService systemUserService;
    @Test
    public void findUser(){
        SystemUser systemUser= systemUserService.findUserByName("admin");
        System.out.println(systemUser.toString());
    }
 
}

詳解mybatis-plus的 mapper.xml 路徑配置的坑

到此這篇關于詳解mybatis-plus的 mapper.xml 路徑配置的坑的文章就介紹到這了,更多相關mybatis-plus mapper.xml路徑配置內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/u013234928/article/details/94060733

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美一级免费视频 | av手机在线免费播放 | 少妇的肉体的满足毛片 | 欧美视频一区二区三区四区 | 成人啪啪18免费网站 | 日日摸夜夜添夜夜添牛牛 | 久久精品成人影院 | 久久久久久久一区二区三区 | 欧美性黄 | 蜜桃网站在线 | 天天夜干| 色视频在线观看 | 亚洲特黄妇女高潮 | xxxx69hd一hd| 369看片你懂的小视频在线观看 | 欧美成人鲁丝片在线观看 | 国产69精品久久久久久 | 久久综合狠狠综合久久 | 欧美亚洲国产日韩 | 娇妻被各种姿势c到高潮小说 | 欧美日韩艺术电影在线 | 国产一区二区精品在线观看 | 精品在线一区二区三区 | 亚洲精品a在线观看 | 免费福利在线视频 | 国产精品视频yy9299一区 | 欧美日韩亚洲一区二区三区 | 91在线色 | 日日草夜夜草 | 亚洲成人国产综合 | 小雪奶水翁胀公吸小说最新章节 | 日本在线看| 成人艳情一二三区 | 毛片视频网站 | 91福利在线观看 | 国产精品久久久久久久不卡 | 国内精品免费一区二区2001 | 狠狠干狠狠操 | 久久久久久久久久网 | 福利一区二区三区视频在线观看 | 免费在线看a |