MyBatis-plus笔记——条件构造器和常用接口

wapper介绍


图片-ygixoeru.png

  • Wapper:条件构造抽象类
    • AbstractWapper:用于查询条件封装,生成 sql 的 where 条件
      • QueryWrapper:查询条件封装
      • UpdateWrapper:Update 条件封装
      • AbstractLambdaWrapper:使用Lambda语法
        • LambdaQueryWrapper:使用Lambda语法使用的查询Wrapper
        • LambdaUpdateWrapper:Lambda 更新封装Wrapper

封装类


查询封装类使用示例

@Test  
public void test01() {  // 查询用户名包含a,年龄在20~30,邮箱信息不为null  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.like("user_name", "a")  .between("age",20, 30)  .isNotNull("email");  userMapper.selectList(queryWrapper).forEach(user -> log.info("用户信息:{}", user));  
}@Test  
public void test02() {  // 查询用户信息,按照年龄降序排序,若年龄相同,则按id升序排序  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.orderByDesc("age").orderByAsc("id");  userMapper.selectList(queryWrapper).forEach(user -> log.info("用户信息:{}", user));  
}
select字句封装

当需要查询指定字段时可以使用 select

@Test  
public void test06 () {  // 查询用户的用户名、年龄、邮箱信息  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.select("user_name", "age", "email");  userMapper.selectList(queryWrapper).forEach(user -> log.info("用户信息:{}", user));  
}
子查询封装
@Test  
public void test07() {  // 查询 uid 小于等于100的用户信息  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.inSql("uid", "select uid from t_user where uid <= 100");  userMapper.selectList(queryWrapper).forEach(user -> log.info("用户信息:{}", user));  
}
删除使用示例
@Test  
public void test03() {  // 删除邮箱地址为 null 的用户信息  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.isNull("email");  int result = userMapper.delete(queryWrapper);  log.info("删除了:{}条数据", result);  
}
修改使用示例
@Test  
public void test04() {  // 将 (年龄大于20并且用户名中包含有a)或邮箱为null的用户信息修改  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.gt("age", 20)  .like("user_name", "a")  .or()  .isNull("email");  User user = new User();  user.setName("小明");  user.setEmail("123@qq.com");  int result = userMapper.update(user, queryWrapper);  log.info("修改了:{}条数据", result);  
}
condition组装条件

通过 condition 条件,可以判断是否要使用该条件作为SQL语句

@Test  
public void test10() {  String username = "a";  Integer ageBegin = null;  Integer ageEnd = 30;  QueryWrapper<User> queryWrapper = new QueryWrapper<>();  queryWrapper.like(StringUtils.isNotBlank(username), "user_name", username) // 判断username 是否不为 空 null 空白符  .ge(ageBegin != null, "age", ageBegin) // 判断ageBegin 是否不为 空 null  .le(ageEnd != null, "age", ageEnd); // 判断ageEnd 是否不为 空 null  userMapper.selectList(queryWrapper).forEach(user -> log.info("用户信息:{}", user));  
}

修改封装类使用示例

@Test  
public void test08() {  // 将用户名中包含有a并且(年龄大于20或邮箱为null)的用户信息修改  UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();  updateWrapper.like("user_name", "a")  .and(i -> i.gt("age", 20).or().isNull("email"));  updateWrapper.set("user_name", "小黑").set("email", "123@qq.com");  userMapper.update(null, updateWrapper);  
}

Lambda封装类

LambdaQueryWrapper
@Test  
public void test11() {  String username = "a";  Integer ageBegin = null;  Integer ageEnd = 30;  LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();  queryWrapper.like(StringUtils.isNotBlank(username), User::getName, username)  .ge(ageBegin != null, User::getAge, ageBegin)  .le(ageEnd != null, User::getAge, ageEnd);  userMapper.selectList(queryWrapper).forEach(user -> log.info("用户信息:{}", user));
LambdaUpdateWrapper
@Test  
public void test12() {  // 将用户名中包含有a并且(年龄大于20或邮箱为null)的用户信息修改  LambdaUpdateWrapper<User> updateWrapper = new LambdaUpdateWrapper<>();  updateWrapper.like(User::getName, "a")  .and(i -> i.gt(User::getAge, 20).or().isNull(User::getEmail));  updateWrapper.set(User::getName, "小黑").set(User::getEmail, "123@qq.com");  userMapper.update(null, updateWrapper);  
}

具体类方法手册

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

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

相关文章

IDEA启动项目报错:Error running ‘‘: Command line is too long.

1、在workspace.xml 2、 在标签 <component name"PropertiesComponent"> 添加 <property name"dynamic.classpath" value"true" />

天地图路径规划功能实现

目录 1、天地图路径规划2、路径规划3、参数说明4、Demo 1、天地图路径规划 天地图Web服务API为用户提供HTTP/HTTPS接口&#xff0c;即开发者可以通过这些接口使用各类型的地理信息数据服务&#xff0c;可以基于此开发跨平台的地理信息应用。 Web服务API对所有用户开放。使用本…

全栈开发之路——前端篇(3)setup和响应式数据

全栈开发一条龙——前端篇 第一篇&#xff1a;框架确定、ide设置与项目创建 第二篇&#xff1a;介绍项目文件意义、组件结构与导入以及setup的引入。 本文为该系列的第三篇&#xff0c;主要讲述Vue核心的setup语法&#xff0c;同时讲解再使用了setup后如何设置响应式数据。 辅助…

Linux专栏05:Linux基本指令之目录处理指令

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Linux专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Linux基本指令之目录处理指令 编号&#xff1a;05 文章目录 Linux基…

Linux的基础IO:文件描述符 重定向本质

目录 前言 文件操作的系统调用接口 open函数 close函数 write函数 read函数 注意事项 文件描述符-fd 小补充 重定向 文件描述符的分配原则 系统调用接口-dup2 缓冲区 缓冲区的刷新策略 对于“2”的理解 小补充 前言 在Linux中一切皆文件&#xff0c;打开文件…

Leetcode 108.将有序数组转换为二叉搜索树

题目描述 给你一个整数数组 nums &#xff0c;其中元素已经按 升序 排列&#xff0c;请你将其转换为一棵 平衡 二叉搜索树。 示例 1&#xff1a; 输入&#xff1a;nums [-10,-3,0,5,9] 输出&#xff1a;[0,-3,9,-10,null,5] 解释&#xff1a;[0,-10,5,null,-3,null,9] 也将被…

改变 centos yum源 repo

centos 使用自带的 repo 源 速度慢&#xff0c;可以改为国内的&#xff0c;需要改两个地方 centos7.repo CentOS-Base.repo 首先备份/etc/yum.repos.d/CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup下载对应版本repo文件…

ICMP详解

3 ICMP ICMP&#xff08;Internet Control Message Protocol&#xff0c;因特网控制报文协议&#xff09;是一个差错报告机制&#xff0c;是TCP/IP协议簇中的一个重要子协议&#xff0c;通常被IP层或更高层协议&#xff08;TCP或UDP&#xff09;使用&#xff0c;属于网络层协议…

Uniapp好看登录注册页面

个人介绍 hello hello~ &#xff0c;这里是 code袁~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f981;作者简介&#xff1a;一名喜欢分享和记录学习的…

4G+北斗太阳能定位终端:一键报警+倾覆报警 双重保障船舶安全

海上作业环境复杂多变&#xff0c;海上航行充满了各种不确定性和风险&#xff0c;安全事故时有发生&#xff0c;因此海上安全与应急响应一直是渔业和海运行业关注的重点。为了提高海上安全保障水平&#xff0c;4G北斗太阳能定位终端应运而生&#xff0c;它集成了一键报警和倾覆…

Edge浏览器新特性深度解析,写作ai免费软件

首先&#xff0c;这篇文章是基于笔尖AI写作进行文章创作的&#xff0c;喜欢的宝子&#xff0c;也可以去体验下&#xff0c;解放双手&#xff0c;上班直接摸鱼~ 按照惯例&#xff0c;先介绍下这款笔尖AI写作&#xff0c;宝子也可以直接下滑跳过看正文~ 笔尖Ai写作&#xff1a;…

【数据结构】:链表的带环问题

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;数据结构 &#x1f337;追光的人&#xff0c;终会万丈光芒 前言&#xff1a; 链表的带环问题在链表中是一类比较难的问题&#xff0c;它对我们的思维有一个比较高的要求&#xff0c;但是这一类…

AI大模型探索之路-训练篇10:大语言模型Transformer库-Tokenizer组件实践

系列篇章&#x1f4a5; AI大模型探索之路-训练篇1&#xff1a;大语言模型微调基础认知 AI大模型探索之路-训练篇2&#xff1a;大语言模型预训练基础认知 AI大模型探索之路-训练篇3&#xff1a;大语言模型全景解读 AI大模型探索之路-训练篇4&#xff1a;大语言模型训练数据集概…

DS:顺序表、单链表的相关OJ题训练

欢迎各位来到 Harper.Lee 的学习小世界&#xff01; 博主主页传送门&#xff1a;Harper.Lee的博客主页 想要一起进步的uu可以来后台找我交流哦&#xff01; 在DS&#xff1a;单链表的实现 和 DS&#xff1a;顺序表的实现这两篇文章中&#xff0c;我详细介绍了顺序表和单链表的…

使用LinkAI创建AI智能体,并快速接入到微信/企微/公众号/钉钉/飞书

​ LinkAI 作为企业级一站式AI Agent 智能体搭建与接入平台&#xff0c;不仅为用户和客户提供能够快速搭建具备行业知识和个性化设定的 AI 智能体的能力&#xff1b;还基于企业级场景提供丰富的应用接入能力&#xff0c;让智能体不再是“玩具”&#xff0c;而是真正能够落地应用…

PHP的数组练习实验

实 验 目 的 掌握索引和关联数组&#xff0c;以及下标和元素概念&#xff1b; 掌握数组创建、初始化&#xff0c;以及元素添加、删除、修改操作&#xff1b; 掌握foreach作用、语法、执行过程和使用&#xff1b; 能应用数组输出表格和数据。 任务1&#xff1a;使用一维索引数…

uniapp0基础编写安卓原生插件和调用第三方jar包和编写语音播报插件之使用jar包插件

前言 如果你不会编写安卓插件,你可以先看看我之前零基础的文章(uniapp0基础编写安卓原生插件和调用第三方jar包和编写语音播报插件之零基础编写安卓插件), 我们使用第三方包,jar包编写安卓插件 开始 把依赖包,放到某个模块的/libs目录(myTestPlug/libs) 还要到build…

R语言的学习—5—多元数据直观表示

1、数据读取 ## 数据整理 d3.1read.xlsx(adstats.xlsx,d3.1,rowNamesT);d3.1 #读取adstats.xlsx表格d3.1数据 barplot(apply(d3.1,1,mean)) #按行做均值条形图 barplot(apply(d3.1,1,mean),las3) barplot(apply(d3.1,2,mean)) #按列做均值图条形图 barplot(a…

C语言数据结构 ---- 单链表实现通讯录

今日备忘录: "折磨我们的往往是想象, 而不是现实." 目录 1. 前言2. 通讯录的功能3. 通讯录的实现思路5. 效果展示6. 完整代码7. 总结 正文开始 1. 前言 顺表实现通讯录: 点击~ 顺序表实现通讯录 在日常生活中&#xff0c;我们经常需要记录和管理大量的联系人信息&…

【研发管理】产品经理知识体系-组合管理

导读&#xff1a;新产品开发的组合管理是一个重要的过程&#xff0c;它涉及到对一系列新产品开发项目进行策略性选择、优先级排序、资源分配和监控。这个过程旨在确保企业能够最大化地利用有限的资源&#xff0c;以实现其战略目标。 目录 1、组合管理、五大目标 2、组合管理的…