2. 条件构造器

构造器结构及作用:

  • Wrapper:条件构造器抽象类,最顶端的父类
    • AbstractWrapper:查询条件封装抽象类,生成 SQL 的 where 条件
      • QueryWrapper:用于对象封装
      • UpdateWrapper:用于条件封装
    • AbstractLambdaWrapper:Lambda 语法使用 Wrapper
      • LambdaQueryWrapper:用于对象封装,使用 Lambda 语法
      • LambdaUpdateWrapper:用于条件封装,使用 Lambda 语法

通常我们使用的都是 QueryWrapper 和 UpdateWrapper,若是想使用 Lambda 语法来编写,也可以使用 LambdaQueryWrapper 和 LambdaUpdateWrapper,通过这些条件构造器,能够很方便地来实现一些复杂的筛选操作,比如:

@Testvoid contextLoads() {// 查询名字中包含'j',年龄大于20岁,邮箱不为空的员工信息QueryWrapper<Employee> wrapper = new QueryWrapper<>();wrapper.like("last_name", "l");wrapper.gt("age", 20);	wrapper.isNotNull("email");List<Employee> list = employeeMapper.selectList(wrapper);list.forEach(System.out::println);}

条件构造器提供了丰富的条件方法帮助我们进行条件的构造,比如 like 方法会建立模糊查询,它是对参数的前后都加上了 % ,若是只想查询以参数开头的名字,则可以使用 likeRight 方法,若是想查询以 参数结尾的名字,,则使用 likeLeft 方法。
年龄的比较也是如此, gt 是大于指定值,若是小于则调用 lt ,大于等于调用 ge ,小于等于调用 le ,不等于调用 ne ,还可以使用 between 方法实现这一过程,相关的其它方法都可以查阅源码进行学习。
因为这些方法返回的其实都是自身实例,所以可使用链式编程:

@Test
void contextLoads() {// 查询名字中包含'j',年龄大于20岁,邮箱不为空的员工信息QueryWrapper<Employee> wrapper = new QueryWrapper<Employee>().likeLeft("last_name", "j").gt("age", 20).isNotNull("email");List<Employee> list = employeeMapper.selectList(wrapper);list.forEach(System.out::println);
}

也可以使用 LambdaQueryWrapper 实现:

@Test
void contextLoads() {// 查询名字中包含'j',年龄大于20岁,邮箱不为空的员工信息LambdaQueryWrapper<Employee> wrapper = new LambdaQueryWrapper<Employee>().like(Employee::getLastName,"j").gt(Employee::getAge,20).isNotNull(Employee::getEmail);List<Employee> list = employeeMapper.selectList(wrapper);list.forEach(System.out::println);
}

这种方式的好处在于对字段的设置不是硬编码,而是采用方法引用的形式,效果与 QueryWrapper 是一样的。
UpdateWrapper 与 QueryWrapper 不同,它的作用是封装更新内容的,比如:

@Test
void contextLoads() {UpdateWrapper<Employee> wrapper = new UpdateWrapper<Employee>().set("age", 50).set("email", "emp@163.com").like("last_name", "j").gt("age", 20);employeeMapper.update(null, wrapper);
}

将名字中包含 j 且年龄大于 20 岁的员工年龄改为 50,邮箱改为 emp@163.com,UpdateWrapper 不仅能够封装更新内容,也能作为查询条件,所以在更新数据时可以直接构造一个 UpdateWrapper 来设置更新内容和条件。

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

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

相关文章

hive sql 和 spark sql的区别

Hive SQL 和 Spark SQL 都是用于在大数据环境中处理结构化数据的工具&#xff0c;但它们有一些关键的区别&#xff1a; 底层计算引擎&#xff1a; Hive SQL&#xff1a;Hive 是建立在 Hadoop 生态系统之上的&#xff0c;使用 MapReduce 作为底层计算引擎。因此&#xff0c;它的…

Elasticsearch 地理空间搜索 - 远超 OpenSearch

作者&#xff1a;来自 Elastic Nathan_Reese 2021 年&#xff0c;OpenSearch 和 OpenSearch Dashboards 开始作为 Elasticsearch 和 Kibana 的分支。 尽管 OpenSearch 和 OpenSearch Dashboards 具有相似的血统&#xff0c;但它们不提供相同的功能。 在分叉时&#xff0c;只能克…

第二十章 调用Callout Library函数 - 使用 $ZF(-6) 按用户索引访问库

文章目录 第二十章 调用Callout Library函数 - 使用 $ZF(-6) 按用户索引访问库使用 $ZF(-6) 按用户索引访问库使用 $ZF(-4,5) 定义系统索引条目使用 $ZF(-6) 调用函数 第二十章 调用Callout Library函数 - 使用 $ZF(-6) 按用户索引访问库 使用 $ZF(-6) 按用户索引访问库 $ZF(…

纯化蛋白质树脂ES-4060_用于吸附蛋白质树脂

蛋白纯化树脂是一种固定在基质中的化学物质&#xff0c;具有选择性地与目标蛋白结合&#xff0c;并通过洗脱将其从混合物中分离出来。蛋白纯化树脂的工作原理主要分为三个步骤:吸附、洗脱和再生。 吸附 蛋白纯化树脂通过与目标蛋白之间的特定相互作用来吸附目标蛋白。这些相互…

2023年全国职业院校技能大赛(高职组)“云计算应用”赛项赛卷5

某企业根据自身业务需求&#xff0c;实施数字化转型&#xff0c;规划和建设数字化平台&#xff0c;平台聚焦“DevOps开发运维一体化”和“数据驱动产品开发”&#xff0c;拟采用开源OpenStack搭建企业内部私有云平台&#xff0c;开源Kubernetes搭建云原生服务平台&#xff0c;选…

《Git学习笔记》

Git概述 什么是Git&#xff1f; Git是一个分布式版本控制工具&#xff0c;主要用于管理开发过程中的源代码文件&#xff08;Java类、xml文件、html页面等&#xff09;&#xff0c;在软件开发过程中被广泛使用。 学完Git之后能做什么 代码回溯&#xff1a;Git在管理文件过程中…

Kafka集群部署 (KRaft模式集群)

KRaft 模式是 Kafka 在 3.0 版本中引入的新模式。KRaft 模式使用了 Raft 共识算法来管理 Kafka 集群元数据。Raft 算法是一种分布式共识算法&#xff0c;具有高可用性、可扩展性和安全性等优势。 在 KRaft 模式下&#xff0c;Kafka 集群中的每个 Broker 都具有和 Zookeeper 类…

飞腾FT2000-4/D2000-8 VPX主板

产品特点 ①国产飞腾FT2000-4或D2000-8处理器 &#xff0c;同一模块兼容两种处理器&#xff0c;可以根据性能需要选择 ②丰富的万兆以太网、千兆以太网、USB、SATA接口&#xff0c;可用作数据处理、存储、通信服务器 ③内部集成FPGA-V7协处理器&#xff0c;支持SRIO、LVDS等…

【LangChain学习之旅】—(5) 提示工程(上):用少样本FewShotTemplate和ExampleSelector创建应景文案

【LangChain学习之旅】—&#xff08;5&#xff09; 提示工程&#xff08;上&#xff09;&#xff1a;用少样本FewShotTemplate和ExampleSelector创建应景文案 提示的结构LangChain 提示模板的类型使用 PromptTemplate使用 ChatPromptTemplateFewShot 的思想起源使用 FewShotPr…

vue+element ui实现图片上传并拖拽进行图片排序

用到的技术栈&#xff1a; vue2element Uivue-dragging 如何使用&#xff1a; 第一步: 安装 npm install awe-dnd --save第二步: 引入 main.js 文件 // 引入组件 import VueDND from awe-dnd // 添加至全局 Vue.use(VueDND)具体项目代码 <el-form-item label"封面…

Org tips

常用快捷方式操作 ** C-c a 显示议事日程Agenda&#xff0c;接以下按键可看到相应日程&#xff1a; a 本周事件 t 显示所有事件 m 查询标签 L 当前缓冲区时间线 s 查询关键词 T 查询带TODO关键词的项 M 查询带TODO关键词的标签 显示已停止事件 q 退出日程表 * a 内置…

Android通过Recyclerview实现流式布局自适应列数及高度

调用 FlowAdapter 跟普通recyclerview一样使用 RecyclerView rvLayout holder.getView(R.id.spe_tag_layout); FlowAdapter rvAdapter new FlowAdapter(); FlowLayoutManager flowLayoutManager new FlowLayoutManager(); rvLayout.setLayoutManager(flowLayoutManager); r…

MyBatis源码分析(六):数据源模块

1. 概述 本文&#xff0c;我们来分享 MyBatis 的数据源模块&#xff0c;对应 datasource 包。如下图所示&#xff1a; ​ 在 MyBatis源码分析&#xff08;二&#xff09;&#xff1a;项目结构 中&#xff0c;简单介绍了这个模块如下&#xff1a; 数据源是实际开发中常用的组件…

css less sass 动态宽高

less height: ~"calc(100% - 30px)";若要需要按照某个比例固定高度可以用 min-height: e("calc(100vh - 184px)")css height: calc(100% - 50px);sass height:calc(100% - var(--height) );

Python Jinja2:强大易用的模板引擎

Jinja2是一个基于Python的模板引擎&#xff0c;它的功能类似于PHP的smarty&#xff0c;J2ee的Freemarker和velocity。 模板引擎的应用场景非常广泛&#xff0c;它可以将动态数据与静态模板结合&#xff0c;提高发效率和代码可维护性。 我们平时接触各类网页&#xff0c;邮件通…

RIS 辅助无线网络:基于模型、启发式和机器学习の优化方法

目录 abstractintroduction相关研究BACKGROUND AND PROBLEM FORMULATIONS FOR OPTIMIZING RIS-AIDED WIRELESS NETWORKSA 优化RIS-AIDED无线网络的背景和问题公式RIS操作原则&#xff1a;RIS控制&#xff1a;RIS部署 B 总速率/容量最大化C 功率最小化D 能源效率最大化E 用户公平…

Opencv实验合集——实验七:二维码和条形码匹配

1.概念 二维码&#xff08;QR码&#xff09; 概念&#xff1a; 二维码是一种矩阵式的二维条码&#xff0c;由黑白方块组成&#xff0c;可以存储大量的信息&#xff0c;包括文本、链接、数字等。QR码的编码方式是在矩阵中通过不同的黑白方块组合表示不同的信息。 特点&#xf…

李沐-《动手学深度学习》--02-目标检测

一 、目标检测算法 1. R-CNN a . 算法步骤 使用启发式搜索算法来选择锚框&#xff08;选出多个锚框大小可能不一&#xff0c;需要使用Rol pooling&#xff09;使用预训练好的模型&#xff08;去掉分类层&#xff09;对每个锚框进行特征抽取&#xff08;如VGG,AlexNet…)训练…

IDEA异常退出重启后项目启动失败解决

背景&#xff1a;使用mac启动idea项目后异常退出&#xff0c;重新打开IDEA后&#xff0c;启动项目失败原因是 端口被占用。 原因&#xff1a;其实就是IDEA异常退出&#xff0c;但是这个项目还在启动&#xff0c;进程没有退出造成的 解决&#xff1a; 使用jdk自带的工具 jps 找到…

招投标系统是Electron的纯内网编辑Office Word,可以设置部分区域可编辑,其他的地方不能编辑吗?

问题&#xff1a; 我们是招投标系统的开发公司&#xff0c;框架是用的Electron&#xff0c;需要在纯内网的环境下编辑Office Word&#xff0c;可以设置部分区域可编辑&#xff0c;其他的地方不能编辑吗&#xff08;如下红框位置&#xff09;并且在用户忘记填写一些区域的时候做…