浅谈MyBatis-plus入门使用

 更新时间:2021年05月24日 15:40:13   作者:天猫精灵998  
这几天本人了解到了MyBatis-plus,一个 Mybatis 增强工具包.经过一番研究,发现这玩意真的好用,不用写任何 xml ,内置通用的 Mapper,而且完全是面向对象编程,文档给的示例代码,跟之前用过的 sequelize (Node.js 的 ORM)非常像,因此本人也尝试了一把, 需要的朋友可以参考下

一、初始化 SpringBoot 项目

首先使用 Spring Initializer 脚手架初始化一个 SpringBoot 项目。然后在 pom.xml 中添加相关的依赖:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.20</version>
</dependency>
 <dependency>
     <groupId>com.baomidou</groupId>
     <artifactId>mybatis-plus-boot-starter</artifactId>
     <version>3.4.2</version>
</dependency>

mysql 依赖用于连接数据库;为了简化代码,添加了 lombok 依赖,用于减少 getter、setter 等方法

二、创建数据表

创建用于测试的数据库及相应的数据表

在这里插入图片描述

这边用于测试的数据库名为 fin-services ,数据表名为 users

三、在 application.yml 中配置 mysql 信息

url 的格式:jdbc:mysql://[ip]:[port]/[db name]

在这里插入图片描述

四、编写用于测试的实体类

在这里插入图片描述

五、编写操作实体类的 Mapper 类

这里直接继承 BaseMapper 类 (mybatis-plus 封装好的类)

在这里插入图片描述

六、启动类中扫描 Mapper 类

在启动类中添加 @MapperScan 注解

在这里插入图片描述

里面的参数是 mapper 文件夹的路径

七、写一个测试类

最后写一个测试类测试一下

在这里插入图片描述

运行一下这个测试方法,成功拿到查询数据

在这里插入图片描述

这边顺便说几个编码的小技巧。这边核心的查询语句其实就是:

List<Users> usersList = usersMapper.selectList(null);

在编写代码的时候,只需要输入 usersMapper.selectList(null).var ,然后按回车,编辑器会自动进行代码补全:

在这里插入图片描述

然后编写 for 循环的语句,对需要进行循环的变量输入 usersList.for ,然后按回车,编辑器会自动进行代码补全:

在这里插入图片描述

对变量打印输出,只需要输入 users.sout ,然后按回车,编辑器会自动进行代码补全:

在这里插入图片描述

八、配置日志

想要查看执行的 sql 语句,可以在 yml 文件中添加配置信息:

mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

如下图所示,执行时会打印出 sql 语句:

在这里插入图片描述

九、遇到的两个坑

之前本人用的 lombok 1.18.10 ,项目运行的时候报了一个错误:

java: java.lang.IllegalAccessError: class lombok.javac.apt.LombokProcessor (in unnamed module @0x55a9b697) cannot access class com.sun.tools.javac.processing.JavacProcessingEnvironment (in module jdk.compiler) because module jdk.compiler does not export com.sun.tools.javac.processing to unnamed module @0x55a9b697

查了下是因为 lombok 1.18.10 与 Java16 不兼容,改用最新版本 1.18.20 解决。可以直接到 maven 官网查询依赖库的最新版本:https://mvnrepository.com/artifact/org.projectlombok/lombok

然后还有一个错误:

org.springframework.jdbc.BadSqlGrammarException:
### Error querying database. Cause: java.sql.SQLSyntaxErrorException: Table ‘fin-services.user' doesn't exist

这是因为之前实体类的类名为 User ,而数据库的表名是 users 。将实体类的类名改为 Users 解决。实体类的类名,需要与数据库的表名对应

十、总结

现在可以实现不带条件的数据库的查询,后续会补充一下查询条件的使用。为了实现完整的后端服务,还需要实现如下功能:

  • 使用 MyBatis-Plus 实现 CURD;
  • 进行统一参数校验;
  • 后台生成 token ,对请求进行 token 校验
  • 后台封装统一响应体 ServerResponse ,统一异常处理

到此这篇关于浅谈MyBatis-plus入门使用的文章就介绍到这了,更多相关MyBatis-plus内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java 设计模式之适配器模式详解

    Java 设计模式之适配器模式详解

    设计模式(Design pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性
    2021-11-11
  • 详解springmvc控制登录用户session失效后跳转登录页面

    详解springmvc控制登录用户session失效后跳转登录页面

    本篇文章主要介绍了springmvc控制登录用户session失效后跳转登录页面,session一旦失效就需要重新登陆,有兴趣的同学可以了解一下。
    2017-01-01
  • 从 PageHelper 到 MyBatis Plugin执行概要及实现原理

    从 PageHelper 到 MyBatis Plugin执行概要及实现原理

    这篇文章主要为大家介绍了从 PageHelper 到 MyBatis Plugin执行概要及实现原理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Java异常链表throw结构assert详细解读

    Java异常链表throw结构assert详细解读

    这篇文章主要给大家介绍了关于Java中方法使用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-08-08
  • Spring利用@Validated注解实现参数校验详解

    Spring利用@Validated注解实现参数校验详解

    这篇文章主要为大家详细介绍了在 Spring 项目中使用 @Validated 进行参数校验的方法和常见应用场景,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-05-05
  • Spring Security自定义登录原理及实现详解

    Spring Security自定义登录原理及实现详解

    这篇文章主要介绍了Spring Security自定义登录原理及实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • spring的事务传播属性REQUIRED_NESTED原理

    spring的事务传播属性REQUIRED_NESTED原理

    这篇文章主要介绍了spring的事务传播属性REQUIRED_NESTED原理,在spring中,要想使用事务中的回滚点,可以使用传播属性NESTED,需要的朋友可以参考下
    2023-05-05
  • java中的枚举类型详细介绍

    java中的枚举类型详细介绍

    枚举中有values方法用于按照枚举定义的顺序生成一个数组,可以用来历遍;接下来将详细介绍
    2012-11-11
  • Java获取支付宝OpenID的实现方法

    Java获取支付宝OpenID的实现方法

    在Java中,通过支付宝开放平台API可以获取用户的OpenID,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-09-09
  • 多线程如何解决for循环效率的问题

    多线程如何解决for循环效率的问题

    这篇文章主要介绍了多线程如何解决for循环效率的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06

最新评论