MyBatis-Plus核心功能详解:条件构造器、自定义SQL与Service接口

news2025/6/21 23:41:28

在Java的Web开发中,MyBatis-Plus作为MyBatis的增强工具,提供了许多实用的功能,极大地简化了数据库操作的开发过程。下面,我们将详细探讨MyBatis-Plus的三大核心功能:条件构造器、自定义SQL以及Service接口。

一、条件构造器

条件构造器(Wrapper)是MyBatis-Plus中的一个重要功能,它使得我们能够以面向对象的方式构建SQL查询条件,而无需手动拼接SQL语句。这不仅提高了代码的可读性和可维护性,还降低了出错的可能性。

MyBatis-Plus的条件构造器主要包括Wrapper、QueryWrapper和UpdateWrapper三个类。其中,Wrapper是一个抽象类,QueryWrapper和UpdateWrapper分别是它的两个实现类。QueryWrapper用于构建查询条件,而UpdateWrapper则用于构建更新条件。

在QueryWrapper中,我们可以使用各种方法来添加查询条件,如eq(等于)、ne(不等于)、gt(大于)、lt(小于)等。这些方法都接受两个参数:字段名和字段值。通过这些方法,我们可以轻松地构建出各种复杂的查询条件。

此外,QueryWrapper还支持使用lambda表达式来构建查询条件。这可以进一步简化代码,并提高代码的可读性。例如,我们可以使用lambda表达式来指定字段名,而无需手动拼写字段名的字符串。

条件构造器(Wrapper)允许我们以面向对象的方式构建SQL查询条件。以下是一个使用QueryWrapper的示例:

 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;  
 import com.example.demo.entity.User;  
 import com.example.demo.mapper.UserMapper;  
 import org.springframework.beans.factory.annotation.Autowired;  
 import org.springframework.stereotype.Service;  
 ​
 import java.util.List;  
 ​
 @Service  
 public class UserService {  
 @Autowired  
 private UserMapper userMapper;  
   
 public List<User> selectUsersByNameAndAge(String name, Integer age) {  
     QueryWrapper<User> queryWrapper = new QueryWrapper<>();  
     if (name != null) {  
         queryWrapper.eq("name", name);  
     }  
     if (age != null) {  
         queryWrapper.eq("age", age);  
     }  
     return userMapper.selectList(queryWrapper);  
 }  
   
 // 使用Lambda表达式的方式  
 public List<User> selectUsersByLambda(String name, Integer age) {  
     QueryWrapper<User> lambdaQueryWrapper = new QueryWrapper<User>().lambda();  
     if (name != null) {  
         lambdaQueryWrapper.eq(User::getName, name);  
     }  
     if (age != null) {  
         lambdaQueryWrapper.eq(User::getAge, age);  
     }  
     return userMapper.selectList(lambdaQueryWrapper);  
 }  
 }    

在上面的示例中,我们定义了一个UserService类,并在其中注入了UserMapper。selectUsersByNameAndAge方法使用传统的字段名字符串来构建查询条件,而selectUsersByLambda方法则使用Lambda表达式来指定字段,这种方式更加类型安全且易于阅读。

案例

(1)基于QueryWrapper的查询

 @Test
 void testQueryWrapper() {
     //1.构造查询条件
     QueryWrapper<User> wrapper = new QueryWrapper<User>()
             .select("id", "username", "info", "balance")
             .like("username", "o")
             .ge("balance", 1000);
     //2.查询
     List<User> users = userMapper.selectList(wrapper);
     users.forEach(System.out::println);
 }

 @Test
 void testUpdateByQueryWrapper() {
     //1.要更新的数据
     User user = new User();
     user.setBalance(2000);
     //2.更新的条件
     QueryWrapper<User> wrapper = new QueryWrapper<User>().eq("username","jack");
     //3.执行更新
     userMapper.update(user,wrapper);
 }

(2)基于UpdateWrapper的更新

 @Test
 void testUpdateWrapper() {
     List<Long> ids = List.of(1L,2L,4L);
     UpdateWrapper<User> wrapper = new UpdateWrapper<User>()
             .setSql("balance = blance - 200")
             .in("id",ids);
     userMapper.update(null,wrapper);
 }

(3)基于Lambda的格式

 @Test
 void testLambdaQueryWrapper() {
     //1.构造查询条件
     LambdaQueryWrapper<User> wrapper = new QueryWrapper<User>().lambda()
             .select(User::getId, User::getUsername, User::getInfo, User::getBalance)
             .like(User::getUsername, "o")
             .ge(User::getBalance, 1000);
     //2.查询
     List<User> users = userMapper.selectList(wrapper);
     users.forEach(System.out::println);
 }

二、自定义SQL

虽然MyBatis-Plus提供了丰富的CRUD操作功能,但在某些特殊场景下,我们仍然需要编写自定义的SQL语句。MyBatis-Plus允许我们在Mapper接口中直接编写自定义的SQL语句,并通过注解或XML文件的方式指定。

在Mapper接口中,我们可以使用MyBatis提供的注解来定义SQL语句,如@Select、@Insert、@Update和@Delete等。这些注解可以接受一个SQL语句作为参数,该SQL语句将被直接执行。通过这种方式,我们可以轻松地实现自定义的数据库操作。

除了使用注解外,我们还可以使用XML文件来定义SQL语句。在XML文件中,我们可以编写完整的SQL语句,并通过命名空间(namespace)和ID来标识不同的SQL语句。然后,在Mapper接口中,我们可以使用@Mapper注解来指定XML文件的位置,并通过方法名来引用XML文件中的SQL语句。

案例:

自定义SQL

① 基于Wrapper构建Where条件

 @Test
 void testCustomSqlUpdate() {
     //1.更新条件
     List<Long> ids = List.of(1L,2L,4L);
     int amount = 200;
     //2.定义条件
     LambdaQueryWrapper<User> wrapper = new QueryWrapper<User>().lambda()
                     .in(User::getId,ids);
     //3.调用自定义SQL方法
     userMapper.updateBalanceByIds(wrapper,amount);
 }

② 在mppper方法参数中用Param注解声明的wrapper变量名称,必须是ew

 public interface UserMapper extends BaseMapper<User> {
     void updateBalanceByIds(@Param("ew") LambdaQueryWrapper<User> wrapper, @Param("amount") int amount);
 ​
 }

③ 自定义SQL,并使用Wrapper条件

 <update id="updateBalanceByIds">
     update user
     set balance = balance - #{amount} ${ew.customSqlSegment}
 </update>

三、Service接口

Service接口是MyBatis-Plus中用于封装业务逻辑的接口。在Service接口中,我们可以定义与业务相关的方法,并调用Mapper接口中的方法来执行数据库操作。通过Service接口,我们可以将业务逻辑与数据访问逻辑进行分离,使得代码更加清晰和易于维护。

在MyBatis-Plus中,我们通常会创建一个与Mapper接口相对应的Service接口,并在Service接口中实现具体的业务逻辑。Service接口的实现类需要继承MyBatis-Plus提供的ServiceImpl类,并注入Mapper接口的实例。通过这种方式,我们可以轻松地访问Mapper接口中的方法,并执行相应的数据库操作。

除了基本的CRUD操作外,Service接口还可以实现更加复杂的业务逻辑,如数据校验、事务控制等。这些业务逻辑可以在Service接口的实现类中进行编写和封装,以便于在其他地方进行调用和使用。

IService是MyBatis-Plus提供的一个通用Service接口,它包含了基本的CRUD操作。例如:

 @Service
 public interface UserService extends IService<User> {
 }

实现类

 public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
 }

在上述代码中,IUserService接口继承了IService<User>接口,表示它是一个通用的User业务处理接口。除了继承自IService的CRUD方法外,我们还可以根据业务需求在UserService接口中添加自定义的业务方法。

IService接口的实现类(如UserServiceImpl)通常由MyBatis-Plus自动生成,我们只需要继承它并实现自定义的业务方法即可。

测试

 @SpringBootTest
 public class IUserServiceTest {
     @Autowired
     private UserService userService;
     @Test
     void testSaveUser(){
         User user = new User();
         user.setId(6L);
         user.setUsername("Lucy");
         user.setPassword("123");
         user.setPhone("18688990011");
         user.setBalance(200);
         user.setInfo("{\"age\": 24, \"intro\": \"英文老师\", \"gender\": \"female\"}");
         user.setCreateTime(LocalDateTime.now());
         user.setUpdateTime(LocalDateTime.now());
 ​
         userService.save(user);
     }
 ​
 }

MyBatis-Plus作为MyBatis的增强工具,提供了丰富的核心功能,包括条件构造器、自定义SQL以及Service接口等。这些功能使得我们在进行Java持久层开发时更加高效和便捷。通过合理地使用这些功能,我们可以提高开发效率,减少错误率,并提升代码的可维护性和可扩展性。

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

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

相关文章

用掼蛋的智慧优化图形化编程体验

周末的午后&#xff0c;阳光透过卧龙家庭院的树叶&#xff0c;在地上洒下一片斑驳的光影。微风轻拂&#xff0c;树叶沙沙作响&#xff0c;为这个宁静的庭院增添了一丝生机。 在庭院的一角&#xff0c;有一张专门用于掼蛋的桌子。桌子周围摆放着几把舒适的椅子&#xff0c;此时&…

Human Serum Albumin ELISA kit(人血清白蛋白HSA)

人血清白蛋白&#xff08;Human Serum Albumin, HSA&#xff09;是人体血液中的血清白蛋白。它约占血清蛋白的一半&#xff0c;由肝脏产生。白蛋白具有运输荷尔蒙、脂肪酸和其他化合物、缓冲pH值和维持血管压力等功能。人血清白蛋白是一种高水溶性球状单体血浆蛋白&#xff0c;…

[AWS] stepfunctions-local

本质是本地docker,只支持异步调用 run aws-stepfunctions-localdocker run -p 8083:8083 \ --mount type=bind,readonly,source=/path/MockConfigFile.json,destination=/home/StepFunctionsLocal/MockConfigFile.json \ -e SFN_MOCK_CONFIG="/home/StepFunctionsLocal/…

ranger 队列划分和权限管控方法

创建用户 创建用户ngk【KDE首页->租户管理->集群用户->添加用户】: 创建用户组ngk_group并绑定 ngk用户【KDE首页->租户管理->集群用户->添加用户组】: 创建角色,并绑定用户组 ngk_group 【KDE首页->租户管理->集群用户->添加角色】: 创建队列…

备忘录怎么改字体样式、字号和颜色?

在日常的工作和生活中&#xff0c;备忘录扮演着举足轻重的角色。每当灵感闪现&#xff0c;或是工作事项需要记录&#xff0c;我总是习惯性地打开我的备忘录&#xff0c;将这些宝贵的想法和任务一一记下 然而&#xff0c;随着使用频率的增加&#xff0c;我发现自己越来越渴望能…

PHP笔记

1. 搭建运行环境 1.1 挂载光盘 [rootredhat200 ~]# mount /dev/sr0 /mnt 1.2 配置仓库 # 查看仓库列表 [rootredhat200 ~]# dnf repolist# 进入到仓库目录 [rootredhat200 ~]# cd /etc/yum.repos.d/ # 编辑仓库文件 [rootredhat200 yum.repos.d]# vim base.repo # 查看仓库…

【antd + vue】Failed to resolve component: a-select-option

一、问题说明 1、出现情况&#xff1a; <a-select>嵌套<a-select-option>&#xff0c;其中<a-select-option>循环&#xff0c;能正常使用&#xff0c;但是控制台警告。 2、控制台警告&#xff1a; [Vue warn]: Failed to resolve component: a-select-op…

【电商API接口】网上商城接口/电商数据接口详情

比价接口背景&#xff1a;电商运营中&#xff0c;数据分析这项工作越来越重要&#xff0c;许多品牌方也越来越热衷去做电商数据分析。不过&#xff0c;全面的数据该如何获取呢&#xff0c;此时&#xff0c;电商数据接口的重要性便凸显出来了。 数据接口主要有以下特点&#xf…

GPT4o速测:约0.5秒延迟的多模态能力

文章目录 1. 测评2. IntroReference 没有剪辑&#xff0c;约0.5秒延迟的多模态能力。 1. 测评 推理速度异常快&#xff0c;比之前快了大概两三倍&#xff0c;对产品端来说是个很好的事情&#xff0c;想用gpt4级别性能终于可以少讨论几句时延影响用户体验了模型指令遵从能力变强…

哔哩哔哩直播通用榜单系统

榜单系统的定位和业务价值 榜单遍布B站直播相关业务的各个角落&#xff0c;直播打赏、直播间互动、付费玩法、互动玩法、活动、主播PK、语聊房、人气主播排名、高价值用户排名、增值集卡、up主充电等等&#xff0c;在这众多的业务场景中&#xff0c;我们能看到各种各样的榜单。…

idea 灵异事件之maven 缓存

方法一 mvn clean install 方法二 强制刷新maven 1 idea 右侧的maven 窗口&#xff1a; 方法三 强制刷新maven 2 右键项目&#xff1a; 上面虽然是重新导入Maven依赖&#xff0c;按理说&#xff0c;IDEA应该根据当前最新的pom.xml来导入依赖&#xff1b; Reload project操作…

Leetcode—2244. 完成所有任务需要的最少轮数【中等】

2024每日刷题&#xff08;136&#xff09; Leetcode—2244. 完成所有任务需要的最少轮数 实现代码 class Solution { public:int minimumRounds(vector<int>& tasks) {unordered_map<int, int> map;for(int task: tasks) {map[task];}int ans 0;// freq 1 …

青否数字人的应用场景有哪些?

数字人作为一种新兴技术&#xff0c;应用场景也非常广泛&#xff1a; 1. 企业宣传和营销&#xff1a;企业可以使用数字人制作形象宣传片或广告视频&#xff0c;吸引更多的客户和用户。 2. 教育培训&#xff1a;数字人可以在教育培训领域得到广泛应用&#xff0c;例如制作交互式…

idea配置MySQL提示

点击sql语句&#xff0c;然后再选择show context actions 然后再选择Inject language or reference 然后再选择MySQL 然后我们会发现sql语句变颜色了 如果表是红色 那么需要我们连接mysql的对于的数据库

2024淘宝天猫618凑单跨店满300减多少及618红包领取口令是什么?

2024年天猫618购物狂欢节全攻略 随着夏日的脚步临近&#xff0c;一年一度的天猫618年中大促也即将拉开帷幕。作为年中最大的购物狂欢节&#xff0c;天猫618不仅汇聚了众多优质商品&#xff0c;还准备了丰富的优惠活动和红包福利&#xff0c;让消费者在享受购物乐趣的同时&…

CSS 块状元素

还是大剑师兰特&#xff1a;曾是美国某知名大学计算机专业研究生&#xff0c;现为航空航海领域高级前端工程师&#xff1b;CSDN知名博主&#xff0c;GIS领域优质创作者&#xff0c;深耕openlayers、leaflet、mapbox、cesium&#xff0c;canvas&#xff0c;webgl&#xff0c;ech…

振弦式应变计的与实际测量值不一致怎么办

在进行结构健康监测或其他工程测量时&#xff0c;精确性和可靠性至关重要。振弦式表面应变计是一种广泛使用的测量工具&#xff0c;它通过测量材料表面的应变来评估结构的应力状态。然而&#xff0c;在实际应用中&#xff0c;振弦式应变计的测量值与实际应变值之间的不一致问题…

F5G-A万兆光网商用启航,挥动FTTR F50星光之翼,北京联通助力首都家庭飞向全光智慧时代...

2001年&#xff0c;王菲在发行的新歌《光之翼》中唱道&#xff1a;静静地按下电源开关/屏幕的色彩越来越亮/在虚拟的城市/找一个让心灵休息的地方/张开透明翅膀/朝着月亮飞翔/搜寻最美一个现世的天堂…… 将时间拨回千禧年&#xff0c;“看不见的城市”“伊托邦”“网络之城”&…

答辩PPT制作成本高?推荐3个aippt工具

这些网站我愿称之为制作答辩PPT的神&#xff01; 很多快要毕业的同学在做答辩PPT的时候总是感觉毫无思路&#xff0c;一窍不通。但这并不是你们的错&#xff0c;对于平时没接触过相关方面&#xff0c;第一次搞答辩PPT的人来说&#xff0c;这是很正常的一件事。一个好的答辩PPT…

携程网站_广州动物园景点评论采集和处理

一、爬取携程网站_广州动物园景点评论数据100条 数据包括&#xff1a;用户名、评论文本内容、发布时间</n> 结果分别保存在userNames&#xff0c;commentDetails commentTimes列表中。 import requests import json import time userNames [] commentDetails [] com…