当前位置:   article > 正文

spring boot 2以上版本整合mybatis_org.mybatis.spring.boot版本

org.mybatis.spring.boot版本

一、背景

 

       最近想复习一下spring boot和mybatis的知识,就搞了一个spring boot项目,也是通过查找网上的资料做的,但是发现大部分整合都是spring boot 1.5版本的,我使用的是2.5.4版本,就出现了许多错误。现在就来记录一下这次实现吧,同时也会实现mybatis自动生成mapper文件。希望对大家有帮助,可以通过git下载进行参考,地址:GitHub - xujiankang6/spring-boot-research

二、实现

1、通过idea创建一个spring boot项目。

 2、添加下面的依赖。

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-web</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.boot</groupId>
  7. <artifactId>spring-boot-starter-test</artifactId>
  8. <scope>test</scope>
  9. </dependency>
  10. <dependency>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-configuration-processor</artifactId>
  13. <optional>true</optional>
  14. </dependency>
  15. <dependency>
  16. <groupId>org.springframework.boot</groupId>
  17. <artifactId>spring-boot-devtools</artifactId>
  18. <optional>true</optional>
  19. </dependency>
  20. <dependency>
  21. <groupId>org.mybatis.spring.boot</groupId>
  22. <artifactId>mybatis-spring-boot-starter</artifactId>
  23. <version>2.0.1</version>
  24. </dependency>
  25. <dependency>
  26. <groupId>org.mybatis.spring.boot</groupId>
  27. <artifactId>mybatis-spring-boot</artifactId>
  28. <version>2.0.1</version>
  29. </dependency>
  30. <dependency>
  31. <groupId>mysql</groupId>
  32. <artifactId>mysql-connector-java</artifactId>
  33. <version>5.1.35</version>
  34. </dependency>
  35. <!--mybatis pagerhelper分页-->
  36. <dependency>
  37. <groupId>com.github.pagehelper</groupId>
  38. <artifactId>pagehelper-spring-boot-starter</artifactId>
  39. <version>1.2.5</version>
  40. </dependency>
  41. <dependency>
  42. <groupId>com.alibaba</groupId>
  43. <artifactId>druid-spring-boot-starter</artifactId>
  44. <version>1.2.5</version>
  45. </dependency>

 3、同时pom文件里面</plugins>标签下面添加自动生成mybatis插件。

(1)后面需要在resources目录下新建这个目录和文件结构。/generator/generatorConfig.xml

  1. <!-- mybatis generator 自动生成代码插件 -->
  2. <plugin>
  3. <groupId>org.mybatis.generator</groupId>
  4. <artifactId>mybatis-generator-maven-plugin</artifactId>
  5. <version>1.3.2</version>
  6. <configuration>
  7. <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
  8. <overwrite>true</overwrite>
  9. <verbose>true</verbose>
  10. </configuration>
  11. </plugin>

4、将application.properties删除,新建application.yml文件,配置端口,mysql数据库,mybatis等。

(1)修改自己的本地数据库名,账户密码。

(2)修改自己实体类要存放的路径。

  1. server:
  2. port: 8080
  3. spring:
  4. datasource:
  5. name: test
  6. url: jdbc:mysql://127.0.0.1:3306/test
  7. username: root
  8. password: 123456
  9. # 使用druid数据源
  10. type: com.alibaba.druid.pool.DruidDataSource
  11. driver-class-name: com.mysql.jdbc.Driver
  12. filters: stat
  13. maxActive: 20
  14. initialSize: 1
  15. maxWait: 60000
  16. minIdle: 1
  17. timeBetweenEvictionRunsMillis: 60000
  18. minEvictableIdleTimeMillis: 300000
  19. validationQuery: select 'x'
  20. testWhileIdle: true
  21. testOnBorrow: false
  22. testOnReturn: false
  23. poolPreparedStatements: true
  24. maxOpenPreparedStatements: 20
  25. ## 该配置节点为独立的节点,有很多同学容易将这个配置放在spring的节点下,导致配置无法被识别
  26. mybatis:
  27. mapper-locations: classpath:mapping/*.xml #注意:一定要对应mapper映射xml文件的所在路径
  28. type-aliases-package: com.example.demo.model # 注意:对应实体类的路径

5、在启动类同级目录和resources目录下新建一些文件目录。

(1)在启动类同级新建controller,mapper,model,service四个目录。

(2)在 resources目录下新建一个mapping目录,用来存放后面自动生成的mapper.xml文件。

(3)新建一个generator目录,同时新建一个generatorConfig.xml文件,跟第三步的配置的自动生成mybatis插件目录一致。文件目录如下,需要修改成自己需要自动创建的表。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE generatorConfiguration
  3. PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
  4. "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
  5. <generatorConfiguration>
  6. <!-- 数据库驱动:选择你的本地硬盘上面的数据库驱动包-->
  7. <classPathEntry location="D:\spring20210828\jar\mysql-connector-java-5.1.25.jar"/>
  8. <context id="DB2Tables" targetRuntime="MyBatis3">
  9. <commentGenerator>
  10. <property name="suppressDate" value="true"/>
  11. <!-- 是否去除自动生成的注释 true:是 : false:否 -->
  12. <property name="suppressAllComments" value="true"/>
  13. </commentGenerator>
  14. <!--数据库链接URL,用户名、密码 -->
  15. <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1/test" userId="root" password="123456">
  16. </jdbcConnection>
  17. <javaTypeResolver>
  18. <property name="forceBigDecimals" value="false"/>
  19. </javaTypeResolver>
  20. <!-- 生成模型的包名和位置-->
  21. <javaModelGenerator targetPackage="com.example.demo.model" targetProject="src/main/java">
  22. <property name="enableSubPackages" value="true"/>
  23. <property name="trimStrings" value="true"/>
  24. </javaModelGenerator>
  25. <!-- 生成映射文件的包名和位置-->
  26. <sqlMapGenerator targetPackage="mapping" targetProject="src/main/resources">
  27. <property name="enableSubPackages" value="true"/>
  28. </sqlMapGenerator>
  29. <!-- 生成DAO的包名和位置-->
  30. <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.mapper" targetProject="src/main/java">
  31. <property name="enableSubPackages" value="true"/>
  32. </javaClientGenerator>
  33. <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名-->
  34. <table tableName="user" domainObjectName="User" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
  35. </context>
  36. </generatorConfiguration>

6、点击Edit  Configurations,新建一个maven项。

(1)命名为generator。

(2)Command line配置为下面的内容。

mybatis-generator:generate -e

 7、执行generator,只需要执行一次就会生成mapper文件和bean类。

(1)注意,只执行一次即可,多次执行generator,UserMapper文件里面会生成重复的方法,启动项目可能会报错。

 8、新建一个service接口

(1)这个接口里面的方法是复制的自动生成的UserMapper接口里面的方法。

  1. public interface UserService {
  2. int deleteByPrimaryKey(Integer uid);
  3. int insert(User record);
  4. int insertSelective(User record);
  5. User selectByPrimaryKey(Integer uid);
  6. int updateByPrimaryKeySelective(User record);
  7. int updateByPrimaryKey(User record);
  8. }

 9、新建service实现类

(1)引入的userMapper类,可能会爆红警告,不过不影响启动。

  1. package com.example.demo.service.impl;
  2. import com.example.demo.mapper.UserMapper;
  3. import com.example.demo.model.User;
  4. import com.example.demo.service.UserService;
  5. import org.springframework.beans.factory.annotation.Autowired;
  6. import org.springframework.stereotype.Service;
  7. /**
  8. * UserServiceImpl
  9. *
  10. * @author jiankang.xu
  11. * @date 2021/8/29
  12. */
  13. @Service
  14. public class UserServiceImpl implements UserService {
  15. @Autowired
  16. private UserMapper userMapper;
  17. @Override
  18. public int deleteByPrimaryKey(Integer uid) {
  19. return userMapper.deleteByPrimaryKey(uid);
  20. }
  21. @Override
  22. public int insert(User record) {
  23. return userMapper.insert(record);
  24. }
  25. @Override
  26. public int insertSelective(User record) {
  27. return userMapper.insertSelective(record);
  28. }
  29. @Override
  30. public User selectByPrimaryKey(Integer uid) {
  31. return userMapper.selectByPrimaryKey(uid);
  32. }
  33. @Override
  34. public int updateByPrimaryKeySelective(User record) {
  35. return userMapper.updateByPrimaryKeySelective(record);
  36. }
  37. @Override
  38. public int updateByPrimaryKey(User record) {
  39. return userMapper.updateByPrimaryKey(record);
  40. }
  41. }

10、新建一个controller类

  1. package com.example.demo.controller;
  2. import com.example.demo.model.User;
  3. import com.example.demo.service.UserService;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.stereotype.Controller;
  6. import org.springframework.web.bind.annotation.PathVariable;
  7. import org.springframework.web.bind.annotation.RequestMapping;
  8. import org.springframework.web.bind.annotation.ResponseBody;
  9. /**
  10. * UserMapperController
  11. *
  12. * @author jiankang.xu
  13. * @date 2021/8/29
  14. */
  15. @Controller
  16. @RequestMapping("/mapper")
  17. public class UserMapperController {
  18. @Autowired
  19. private UserService userService;
  20. @RequestMapping("/getuser/{uid}")
  21. @ResponseBody
  22. public User getUser(@PathVariable String uid){
  23. return userService.selectByPrimaryKey(Integer.valueOf(uid));
  24. }
  25. }

11、启动spring boot项目,访问这个端口,就可以查询到数据库里的数据了。

三、问题

1、NoClassDefFoundError: org/springframework/boot/bind/RelaxedDataBinder

(1)这个错误是alibaba的druid数据库连接池的版本过低,原来我的版本是低于1.2.5的,spring boot 1x版本使用不会报错,我的版本是2x以上,所以改为1.2.5就不会报错了。

  1. <!-- alibaba的druid数据库连接池 -->
  2. <dependency>
  3. <groupId>com.alibaba</groupId>
  4. <artifactId>druid-spring-boot-starter</artifactId>
  5. <version>1.2.5</version>
  6. </dependency>

2、Error creating bean with name 'com.github.pagehelper.autoconfigure.PageHelperAutoConfiguration'

(1)这个错误是mybatis pagerhelper分页依赖版本太低,不支持spring boot 2x版本,改为下面的就好了。

  1. <!--mybatis pagerhelper分页-->
  2. <dependency>
  3. <groupId>com.github.pagehelper</groupId>
  4. <artifactId>pagehelper-spring-boot-starter</artifactId>
  5. <version>1.2.5</version>
  6. </dependency>

3、Error creating bean with name 'userMapper' defined in file

(1)这个在引入userMapper时,需要添加@Autowired。

四、总结

       以上就是关于spring boot 2以上版本整合mybatis的全部内容,希望能够帮到大家,这篇文章可以收获学会spring boot整合mybatis,自动生成mapper文件等等,觉得不错的话,欢迎微信搜索关注java基础笔记,后面会不断更新相关知识,大家一起进步。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/498167
推荐阅读
相关标签
  

闽ICP备14008679号