广告
返回顶部
首页 > 资讯 > 后端开发 > Python >浅谈MyBatis-plus入门使用
  • 401
分享到

浅谈MyBatis-plus入门使用

2024-04-02 19:04:59 401人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录一、初始化 SpringBoot 项目二、创建数据表三、在 application.yml 中配置 Mysql 信息四、编写用于测试的实体类五、编写操作实体类的 Mapper 类

一、初始化 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内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 浅谈MyBatis-plus入门使用

本文链接: https://www.lsjlt.com/news/126711.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 浅谈MyBatis-plus入门使用
    目录一、初始化 SpringBoot 项目二、创建数据表三、在 application.yml 中配置 mysql 信息四、编写用于测试的实体类五、编写操作实体类的 Mapper 类...
    99+
    2022-11-12
  • mybatis-plus中BaseMapper入门使用
    目录入门使用BaseMapper完成增删改查BaseMapper各方法详解InsertDeleteUpdateSelect具体教程参考官网文档: baomidou.com/ 入门使...
    99+
    2022-11-12
  • 浅谈Mybatis Plus的BaseMapper的方法是如何注入的
    目录Mybatis Plus的BaseMapper的方法Mybatis Plus的初始化方法MybatisPlusAutoConfiguration中的SqlSessionFacto...
    99+
    2022-11-12
  • java中MyBatis-plus入门使用的示例分析
    小编给大家分享一下java中MyBatis-plus入门使用的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、初始化 SpringBoot 项目首先使用...
    99+
    2023-06-15
  • 深入浅出JAVA MyBatis-快速入门
    目录创建项目前的环境搭建简介特点(开始)创建Maven项目,导入依赖创建一个新的Maven项目(开始)在数据库中创建表创建表详细信息从 XML 中构建 SqlSessionFacto...
    99+
    2022-11-12
  • C++入门浅谈之类和对象
    目录一、面向过程vs面向对象二、类的限定符及封装三、类的实例化四、this指针五、默认成员函数1. 构造函数2. 析构函数3. 拷贝函数4. 赋值运算符重载总结一、面向过程vs面向对...
    99+
    2022-11-12
  • MyBatis-Plus简介和快速入门教程
    目录 一、MyBatis-Plus简介(来自官网)二、快速开始三、通用CRUD3.1 insert(插入操作)3.2 updateById(更新操作)3.3 查询操作——各...
    99+
    2022-11-12
  • 浅谈Mybatis通用Mapper使用方法
    对单表进行增删改查是项目中不可避免的需求,Mybatis的通用Mapper插件使这些操作变得简单添加maven依赖在对应工程的pom.xml文件中添加<dependency> <groupId>javax.pers...
    99+
    2023-05-31
    mybatis mapper pp
  • Python入门_浅谈for循环、while循环
    Python中有两种循环,分别为:for循环和while循环。 1. for循环 for循环可以用来遍历某一对象(遍历:通俗点说,就是把这个循环中的第一个元素到最后一个元素依次访问一次)。for循环的基本结...
    99+
    2022-06-04
    浅谈 入门 Python
  • 浅谈Vue入门需掌握的知识
    Vue作为一款目前最流行的前端框架之一,是许多前端开发工程师的不二选择。最近我在前端岗位上也运用Vue实现了几款产品,那么今天来分享一下Vue是什么,以及我对Vue的见解。 一、定义...
    99+
    2022-11-12
  • 浅谈MyBatis中@MapKey的妙用
    目录MyBatis @MapKey的妙用背景实现源码分析思考Mybatis @MapKey分析1. MapKey注解有啥功能2. MapKey的源码分析1. MapperMethod...
    99+
    2022-11-13
  • 浅谈Springboot下引入mybatis遇到的坑点
    一、 springBoot + Mybatis 配置完成后,访问数据库遇到的问题 首先出现这个问题,肯定是xml文件与mapper接口没有匹配上,甚至是xml文件根本没有被扫描到。...
    99+
    2022-11-12
  • Mybatis-Plus环境配置与入门案例分析
    目录1 初识Mybatis-Plus2 入门案例前期环境准备各层代码编写入门案例查询结果1 初识Mybatis-Plus   MyBatis-Plus简称 MP,是一个 MyBati...
    99+
    2022-11-13
  • MyBatis批量插入耗时踩坑经验浅谈
    问题 因项目有新功能需求,看完需求后,开始无脑写bug,写完开始调bug,因为功能原因,我在写业务逻辑的时候部分的数据采用了批量保存,没多想,懒的写sql就直接用了MyBatis自带的saveBatc...
    99+
    2023-09-07
    mybatis mysql 数据库 Java
  • Python入门_浅谈逻辑判断与运算符
    这是关于Python的第6篇文章,主要介绍下逻辑判断与运算符。 (一) 逻辑判断: 如果要实现一个复杂的功能程序,逻辑判断必不可少。逻辑判断的最基本标准:布尔类型。 布尔类型只有两个值:True和False...
    99+
    2022-06-04
    浅谈 运算符 逻辑
  • 一篇文章带你学习Mybatis-Plus(新手入门)
    目录Mybatis-Plus1.快速入门地址:安装 | MyBatis-Plus (baomidou.com)2.创建数据库mybatis-plus3.创建springboot项目,...
    99+
    2022-11-12
  • Mybatis-Plus入门系列(20) -兼容多种数据库
    有道无术,术尚可求,有术无道,止于术。 文章目录 前言方案分析1. 分页2. XML自定义SQL 案例演示1. 配置2. 简单分页查询3. 带方言的分页查询 参考 前言 在我们实际开发软件产品过程中,数据库...
    99+
    2023-08-23
    数据库 mybatis oracle
  • SpringBoot整合mybatis-plus快速入门超详细教程
    目录前言mybatis-plus 简介mybatis-plus 优点相关链接mybatis-plus实例1、示例项目结构2、数据库准备3、pom.xml:4、application....
    99+
    2022-11-12
  • MyBatis-Plus 使用枚举自动关联注入
    目录什么是枚举自动注入? 实际效果 实现步骤 踩坑 解决方法 参数解析 总结 什么是枚举自动注入? 官方文档是这么解释的 解决了繁琐的配置,让 mybatis 优雅的使用枚举属性!...
    99+
    2022-11-12
  • 浅谈MyBatis原生批量插入的坑与解决方案
    目录原生批量插入的“坑”解决方案分片 Demo 实战原生批量插入分片实现总结前面的文章咱们讲了 MyBatis 批量插入的 3 种方法:循环单次插入、MyBatis Plus 批量插...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作