MyBatisPlus学习三:Service接口、代码生成器

学习教程

黑马程序员最新MybatisPlus全套视频教程,4小时快速精通mybatis-plus框架

Service接口

简介
MyBatis-Plus框架中,Service接口的作用是为实体类提供一系列的通用CRUD(增删改查)操作方法。通常情况下,Service接口中的方法会对应数据库表中的操作,例如插入一条数据、根据主键查询数据、更新数据等。

Service接口与继承BaseMapper的区别在于,Service接口封装了一些常用的数据库操作方法,使得开发者可以直接调用这些方法,而不需要自己手动编写SQL语句和操作数据库。这样可以减少开发者的工作量,并提高开发效率。

另外,Service接口还可以定义一些业务相关的方法,例如根据条件查询数据、批量插入数据等。这些方法可以根据具体的业务需求来定义,提供了更加灵活的操作方式。

而继承BaseMapper接口,则是为了实现自定义的数据库操作方法。通过继承BaseMapper接口,可以使用MyBatis-Plus提供的一系列的数据库操作方法,例如插入、更新、删除等。这样可以方便地使用MyBatis-Plus的功能,并减少手动编写SQL语句的工作量。

总之,Service接口和继承BaseMapper接口都是为了简化数据库操作的方式,提高开发效率,并提供了一些常用的数据库操作方法。具体使用哪种方式,可以根据具体的业务需求和开发习惯来选择。

基本步骤

1、需要有一个自己的Service接口,这个接口要继承
UserService

// 自定义的接口,继承mybatis-plus中的IService接口
public interface UserService extends IService<User> {
}

2、对自己的Service接口进行继承并实现
UserServiceImpl

// 1、继承mybatis-plus提供的Service实现类,指定对应的mapper接口和实体类
// 2、继承自定义的UserService接口
// 3、添加上@Service注解@Service
public class UserServiceImpl  extends ServiceImpl<UserMapper, User> implements UserService {
}

3、使用mybatis-plus实现好的方法进行查询
UserController

@Controller
public class UserController {@Autowiredprivate UserService userService;@RequestMapping("/userlist")@ResponseBodypublic List<User> selectAllUser() {// 查询所有用户,调用mybatis-plus实现的方法List<User> users = userService.list();return users;}
}

文件梳理
现有文件如下

UserController 定义前端访问的接口,后端调用UserServiceImpl中的方法来处理数据库数据
User实体类,与数据库表对应
UserMapper 定义操作sql的方法,主要是特殊需要写sql的方法,普通操作数据库可以通过mybatis-plus提供的方法实现
UserServiceImpl UserService的实现类,编写主要的业务逻辑。
UserService 定义提供哪些操作方法。UserService类似饭店,提供了菜单列表,而UserServiceImpl就是具体做菜的厨师。
UserMapper.xml 编写具体的sql语句
在这里插入图片描述

现在假设mybatis-plus没有提供查询名称为李四的用户,这时可以通过编写sql实现。

UserController

 public List<User> selectAllUser() {// 查询名称为李四的用户List<User> users = userService.getLisi();return users;}

UserService

public interface UserService extends IService<User> {// 获取李四List<User> getLisi();
}

UserServiceImpl

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {@Overridepublic List<User> getLisi() {// 调用baseMapper定义的操作sql的方法// 这里不需要使用userMapper,因为ServiceImpl里有baseMapper,baseMapper实际上就是UserMapperList<User> userList = baseMapper.getLisi();return userList;}
}

在这里插入图片描述
UserServiceImpl 中也可以直接调用ServiceImpl提供的方法

在这里插入图片描述

UserMapper

@Mapper
public interface UserMapper extends BaseMapper<User> {List<User> getLisi();
}

UserMapper.xml

 <select id="getLisi" resultType="org.example.springboot.entity.User">select * from user where name = '李四'</select>

这个流程感觉怪怪的,但是好像就是这样写,具体为啥不清楚,比较刚开始学习

在这里插入图片描述

ServiceImpl常用方法
mybatis-plusServiceImpl实现了很多方法。
一般查询单挑数据的方法是get开头、多条数据是list开头;
删除方法是remove开头;
新增方法是save开头;
更新方法是update开头;

对于mybatis-plus没有提供的,可以通过自定义mapper接口,执行sql语句来实现。

Lambda

在使用BaseMapper我们可以使用提供好的Lambda 表达式。当我们使用Service时也可以使用Lambda 表达式。

UserController

public List<User> selectAllUser() {// 使用Lambda表达式查询所有年龄大于30的男生int age = 30;int sex = 1;List<User> users = userService.getAllBoy(age,sex);return users;
}

UserService

 // 查询男生List<User> getAllBoy(@Param("age") Integer age, @Param("sex") Integer sex);

UserServiceImpl

 // 查询男生@Overridepublic List<User> getAllBoy(@Param("age") Integer age, @Param("sex") Integer sex) {// 这里不需要使用if判断值是否存在,而是使用lambdaQuery处理List<User> userList = lambdaQuery().gt(age != null, User::getAge, age)  // 年龄存在时条件生效.eq(sex != null, User::getSex, sex) // 性别存在时条件生效.list(); // 返回一个集合return userList;}

在这里插入图片描述

代码生成

在上面的内容中,我们需要写很多文件、代码。但是这些代码很多内容都是相同的,这里我们可以使用第三方插件来为我们生成这些固定的内容。

视频教程:代码生成器

插件是mybatisplus
在这里插入图片描述
下载完成后需要配置数据库,因为该插件是基于数据库的表来生成代码的。不同版本的IDEA,设置的位置可能不一样。我的版本是IntelliJ IDEA 2023.3.2。这一步可能可以省略,如果不行的话,在进行配置
在这里插入图片描述
我本地使用的是mysql,以mysql为例
在这里插入图片描述
数据库配置好后,可以看到自己的数据库
在这里插入图片描述
在这里插入图片描述
这里也要配置一下,配置完成后可以测试是否连接成功
在这里插入图片描述
dbUrl 格式如下:jdbc:mysql://localhost:3306/your_database?serverTimezone=Asia/Shanghaiyour_database替换为你自己数据库的名称

配置代码生成,找到code generator 按钮。我的在 tools
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
稍微有点问题,路径分隔符不对
在这里插入图片描述
修改一下路径,/ 修改为.
在这里插入图片描述
第一次生成之后,最好检查一下生成的文件是否有什么问题。这样方便后续修改其配置。我这里出现的问题就是包地址填写的有问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/601162.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PyTorch 入门学习数据操作之创建

简介 在深度学习中&#xff0c;我们通常会频繁地对数据进行操作&#xff1b;要操作一般就需要先创建。 官方介绍 The torch package contains data structures for multi-dimensional tensors and defines mathematical operations over these tensors. Additionally, it pr…

k8s-二进制部署

ETCD master节点 制作证书 1、下载证书工具 [rootmaster ~]# wget https://pkg.cfssl.org/R1.2/cfssl_linux-amd64 --no-check-certificate [rootmaster ~]# wget https://pkg.cfssl.org/R1.2/cfssljson_linux-amd64 --no-check-certificate [rootmaster ~]# wget https://…

SpringMVC通用后台管理系统源码

整体的SSM后台管理框架功能已经初具雏形&#xff0c;前端界面风格采用了结构简单、 性能优良、页面美观大的Layui页面展示框架 数据库支持了SQLserver,只需修改配置文件即可实现数据库之间的转换。 系统工具中加入了定时任务管理和cron生成器&#xff0c;轻松实现系统调度问…

【源码解析】Apache RocketMQ发送消息源码

send message源码解析 引入 send message方法作为我们经常使用的方法&#xff0c;平时我们很难去关注他底层到底做了什么。大部分人只知道通过send message方法可以将消息发送到broker&#xff0c;然后供消费者进行消费。其实不然&#xff0c;消息从客户端发送到broker&#x…

ssm基于vue.js的购物商场的设计与实现论文

摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装购物商场软件来发挥其高效地信息处理的作用&#xff0c;可以…

Spring Cloud Bus 相关问题及答案(2024)

1、什么是 Spring Cloud Bus&#xff1f; Spring Cloud Bus 是建立在 Spring Cloud 的基础之上&#xff0c;用于处理微服务架构中各服务实例间消息通信的框架。它与 Spring Cloud Config 结合使用时&#xff0c;可以提供一种动态刷新配置的能力&#xff0c;不需要重启服务实例…

阿里云服务器配置选择推荐方案

阿里云服务器配置怎么选择合适&#xff1f;CPU内存、公网带宽和ECS实例规格怎么选择合适&#xff1f;阿里云服务器网aliyunfuwuqi.com建议根据实际使用场景选择&#xff0c;例如企业网站后台、自建数据库、企业OA、ERP等办公系统、线下IDC直接映射、高性能计算和大游戏并发&…

cissp 第10章 : 物理安全要求

10.1 站点与设施设计的安全原则 物理控制是安全防护的第一条防线&#xff0c;而人员是最后一道防线。 10.1.1 安全设施计划 安全设施计划通过关键路径分析完成。 关键路径分析用于找出关键应用、流程、运营以及所有必要支撑元索间的关系。 技术融合指的是各种技术、解决方案…

性能优化-OpenMP基础教程(三)

本文主要介绍OpenMP并行编程的环境变量和实战、主要对比理解嵌套并行的效果。 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;高性能&#xff08;HPC&#xff09;开发基础教程 &#x1f380;CSDN主页 发狂的小花 &…

书生·浦语大模型全链路开源体系 学习笔记 第一课

背景 大模型是发展人工通用人工智能的一个重要途径&#xff0c;能够解决多种任务和多种模态&#xff0c;展示了一个更面向更高阶的智能的潜在途径。大模型的发展历程是从专用模型到通用模型的过程&#xff0c;从语音识别、图像识别、人脸识别等专用模型&#xff0c;到通用的大…

Java8内置四大核心函数式接口

先来看几个例子,主要练习策略模式: 用策略模式的做法 定义个接口 其实像这样的接口并不需要我们自己创建 java8推出的Lambda表达式主要就是为了简化开发,而Lambda表达式 的应用主要是针对与函数式接口,自然也推出了对应的一些接口 /*** Java8 内置的四大核心函数式接口** C…

找城市(100%用例)C卷 (JavaPythonC++Node.jsswift)

一张地图上有n个城市,城市和城市之间有且只有一条道路相连:要么直接相连,要么通过其它城市中转相连(可中转一次或多次)。城市与城市之间的道路 都不会成环 。 当切断通往某个城市 i 的所有道路后,地图上将分为多个连通的城市群,设该城市 i 的聚集度为 DP i (Degree of…

7-2 jmu-java-m02-使用二维数组存储多元线性方程组 --笔记篇

题目 题面 可以使用二维数组存储来存储线性方程组的系数与常数。比如&#xff0c;对于如下3元线性方程组 3xyz1 6x2yz-1 -2x2yz7 可以使用二位数组存储 2 1 1 1 6 2 1 -1 -2 2 1 7 编写一个程序可以存储n元线性方程组 输入格式: 整数n&#xff0c;代表n元 n行、每行n1列线性方…

【C++】STL 算法 ③ ( 函数对象中存储状态 | 函数对象作为参数传递时值传递问题 | for_each 算法的 函数对象 参数是值传递 )

文章目录 一、函数对象中存储状态1、函数对象中存储状态简介2、示例分析 二、函数对象作为参数传递时值传递问题1、for_each 算法的 函数对象 参数是值传递2、代码示例 - for_each 函数的 函数对象 参数在外部不保留状态3、代码示例 - for_each 函数的 函数对象 返回值 一、函数…

权威认可!甄知科技猪齿鱼产品荣获信创产品评估证书

近日&#xff0c;依据《信息技术应用创新产品评估规范 第1部分&#xff1a;应用软件》&#xff08;T/SSIA 2001-2022&#xff09;&#xff0c;经过严格评估&#xff0c;甄知科技旗下自主研发的猪齿鱼数智化开发管理平台 V2.0.0&#xff0c;通过信创测试认证&#xff0c;获得上海…

差分约束算法

差分约束 差分约束系统包含 m m m个涉及 n n n个变量的差额限制条件&#xff0c;这些差额限制条件每个都是形式为 x i − x j ≤ b ∈ [ 1 , m ] x_i-x_j\leq b_{\in[1,m]} xi​−xj​≤b∈[1,m]​的简单线性不等式。 通常我们要求解出一组可行解。 最短路差分约束 如果我们…

12.15 log 122.买卖股票的最佳时机 II,55. 跳跃游戏

122.买卖股票的最佳时机 II class Solution { public:int maxProfit(vector<int>& prices) {int result0;for(int i0;i<prices.size();i){if(i>0&&prices[i]-prices[i-1]>0){resultprices[i]-prices[i-1];}}return result;} }; 这道题贪心贪的时每…

ubuntu 22 virt-manger(kvm)安装winxp; ubuntu22体验 firebird3.0

安装 、启动 virt-manager sudo apt install virt-manager sudo systemctl start libvirtdsudo virt-manager安装windowsXP 安装过程截图如下 要点1 启用 “包括寿终正寝的操作系统” win_xp.iso 安装过程 &#xff1a; 从winXp.iso启动, 执行完自己重启从硬盘重启&#xff0c…

稿件代写3个不可或缺的步骤让你事半功倍-华媒舍

作为一个需求频繁的作者&#xff0c;你可能会面临大量的稿件代写任务。但是&#xff0c;你是否曾经为提高文章质量而苦恼过&#xff1f;是否希望在有限的时间内完成更多的代写任务&#xff1f;本篇文章将向你介绍三个不可或缺的稿件代写步骤&#xff0c;帮助你事半功倍&#xf…

Redis高级特性和应用(慢查询、Pipeline、事务、Lua)

Redis的慢查询 许多存储系统(例如 MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间,当超过预设阀值,就将这条命令的相关信息(例如:发生时间,耗时,命令的详细信息)记录下来,Redis也提供了类似…