BaseMapper 中的方法

news2025/1/12 1:11:20

BaseMapper 中的方法:

插入

  1. int insert(T entity) - 插入一条记录。

删除

  1. int deleteById(Serializable id) - 根据主键ID删除记录。

  2. int deleteById(T entity) - 根据实体对象(ID)删除记录。

  3. int deleteByMap(Map<String, Object> columnMap) - 根据列名-值对的条件删除记录。

  4. int delete(Wrapper<T> queryWrapper) - 根据条件对象删除记录。

  5. int deleteBatchIds(Collection<?> idList) - 批量删除记录,根据主键ID列表或实体列表。

更新

  1. int updateById(T entity) - 根据主键ID更新记录。

  2. int update(T entity, Wrapper<T> updateWrapper) - 根据条件对象更新记录。

查询

  1. T selectById(Serializable id) - 根据主键ID查询一条记录。

  2. List<T> selectBatchIds(Collection<? extends Serializable> idList) - 根据主键ID列表批量查询记录。

  3. List<T> selectByMap(Map<String, Object> columnMap) - 根据列名-值对的条件查询记录。

  4. T selectOne(Wrapper<T> queryWrapper) - 根据条件对象查询一条记录。

  5. Long selectCount(Wrapper<T> queryWrapper) - 根据条件对象查询总记录数。

  6. List<T> selectList(Wrapper<T> queryWrapper) - 根据条件对象查询全部记录。

  7. List<Map<String, Object>> selectMaps(Wrapper<T> queryWrapper) - 根据条件对象查询全部记录,并返回Map列表。

  8. List<Object> selectObjs(Wrapper<T> queryWrapper) - 根据条件对象查询全部记录,并只返回第一个字段的值。

  9. <P extends IPage<T>> P selectPage(P page, Wrapper<T> queryWrapper) - 根据条件对象分页查询记录。

  10. <P extends IPage<Map<String, Object>>> P selectMapsPage(P page, Wrapper<T> queryWrapper) - 根据条件对象分页查询记录,并返回Map列表。

boolean exists(Wrapper<T> queryWrapper) - 根据条件对象判断是否存在记录。

这四个查询方法分别提供了不同的查询策略:

  1. selectById(Serializable id): 这个方法是基于主键 ID 来查询单条记录。传入一个序列化的 ID,如果存在匹配的记录,就返回该记录的实体对象;如果没有匹配的记录,则返回 null

  2. selectBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList): 这个方法是基于主键 ID 列表来批量查询记录。传入一个包含序列化的 ID 的集合,返回一个列表,包含与 ID 集合中所有 ID 匹配的记录的实体对象。如果没有匹配的记录,则返回空列表。

  3. selectByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap): 这个方法是基于列的映射来查询记录。传入一个映射,其中键是列名,值是列的值,返回一个列表,包含与所有列映射匹配的记录的实体对象。如果没有匹配的记录,则返回空列表。《就是:一个传字段名,一个传值》

  4. selectOne(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper): 这个方法是基于实体对象封装操作类来查询单条记录。传入一个 Wrapper,它封装了查询条件。如果查询结果有多条记录,会抛出异常;如果有一条记录,就返回该记录的实体对象;如果没有匹配的记录,则返回 null

  1. List<T> selectList(Wrapper<T> queryWrapper)

    此方法返回一个实体对象的列表。每个实体对象代表查询结果中的一条记录,其中包含了该记录的所有字段。这个方法更适合于当你在应用程序中需要使用记录的所有信息时使用。

    例如,如果你有一个 User 实体类,每个 User 对象会包含 idnameemail 等属性,那么 selectList 会返回 List<User>,每个 User 对象都代表查询结果中的一条用户记录。

  2. List<Map<String, Object>> selectMaps(Wrapper<T> queryWrapper)

    此方法返回一个 Map 的列表,每个 Map 代表查询结果中的一条记录,其中 Map 的键是字段名,值是字段的值。这个方法更适合于当你需要更灵活地处理查询结果时使用,比如需要转换成 JSON 或者其他数据结构。

    例如,如果查询结果中包含 idnameemail 等字段,那么 selectMaps 会返回如下结构的列表:

    [ {"id": 1, "name": "John", "email": "john@example.com"},
     {"id": 2, "name": "Jane", "email": "jane@example.com"}, 
    // ... 其他记录 ]

选择依据:

  • 如果你需要处理实体对象,并在应用程序中使用这些对象,那么 selectList 是更好的选择。
  • 如果你更倾向于处理原始数据,或者需要更灵活地处理查询结果(例如,转换字段名或值),那么 selectMaps 是更好的选择。

 

 

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

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

相关文章

快速用Python进行数据分析技巧详解

概要 一些小提示和小技巧可能是非常有用的&#xff0c;特别是在编程领域。有时候使用一点点黑客技术&#xff0c;既可以节省时间&#xff0c;还可能挽救“生命”。 一个小小的快捷方式或附加组件有时真是天赐之物&#xff0c;并且可以成为真正的生产力助推器。所以&#xff0…

【SpringCloud】微服务技术栈入门1 - 远程服务调用、Eureka以及Ribbon

目录 远程服务调用RestTemplate Eureka简要概念配置 Eureka 环境设置 Eureka ClientEureka 服务发现 Ribbon工作流程配置与使用 Ribbon饥饿加载 远程服务调用 RestTemplate RestTemplate 可以模拟客户端来向另外一个后端执行请求 黑马给出的微服务项目中&#xff0c;有两个 …

漏刻有时数据可视化Echarts组件开发(28):异形柱图、pictorialBar和dataZoom组件的使用

构建容器 var dom document.getElementById(container);var myChart echarts.init(dom, null, {renderer: canvas,useDirtyRect: false});模拟数据 var dataList [{name: 班级一, value: 120, max: 120, min: 20},{name: 班级二, value: 183, max: 200, min: 20},{name: 班级…

Windows如何删除“$WINDOWS.~BT“文件夹,解决权限不足无法删除

$WINDOWS.~BT是干嘛的 $Windows.BT是升级或者安装Windows操作系统中间过程中产生的临时文件夹&#xff0c;一般用于保存下载后的升级文件&#xff0c;或者安装过程中复制文件时产生的。用于保存Windows安装记录, 包括配置资料, 错误报告等, 如果安装失败便可反馈给微软公司&am…

pytorch学习3(pytorch手写数字识别练习)

网络模型 设置三层网络&#xff0c;一般最后一层激活函数不选择relu 任务步骤 手写数字识别任务共有四个步骤&#xff1a; 1、数据加载--Load Data 2、构建网络--Build Model 3、训练--Train 4、测试--Test实战 1、导入各种需要的包 import torch from torch import nn f…

Matlab图像处理-区域特征

凹凸性 设P是图像子集S中的点&#xff0c;若通过的每条直线只与S相交一次&#xff0c;则称S为发自P的星形&#xff0c;也就是站在P点能看到S的所有点。 满足下列条件之一&#xff0c;称此为凸状的&#xff1a; 1.从S中每点看&#xff0c;S都是星形的&#xff1b; 2.对S中任…

软件设计师笔记系列(四)

&#x1f600;前言 随着技术的快速发展&#xff0c;软件已经成为我们日常生活中不可或缺的一部分。从智能手机应用到大型企业系统&#xff0c;软件都在为我们提供便利、增强效率和创造价值。然而&#xff0c;随之而来的是对软件质量的日益增长的关注。软件的质量不仅关乎其功能…

C语言中的虚拟地址

虚拟地址 虚拟地址空间 对于操作系统而言&#xff0c;每个进程所得到的虚拟地址都在一个独立的固定的范围内&#xff0c;不会超过这个范围&#xff0c;我们把这个范围称为虚拟地址空间。所谓的虚拟地址空间本质就是一个地址范围&#xff0c;表示程序的寻址能力。对于32位系统…

Python 在 JMeter 中如何使用?

要在JMeter中使用Python&#xff0c;需要使用JSR223 Sampler元素来执行Python脚本。使用JSR223 Sampler执行Python脚本时&#xff0c;需要确保已在JMeter中配置了Python解释器&#xff0c;并设置了正确的环境路径。 1、确保JMeter已安装Python解释器&#xff0c;并将解释器的路…

时序预测 | MATLAB实现POA-CNN-BiGRU鹈鹕算法优化卷积双向门控循环单元时间序列预测

时序预测 | MATLAB实现POA-CNN-BiGRU鹈鹕算法优化卷积双向门控循环单元时间序列预测 目录 时序预测 | MATLAB实现POA-CNN-BiGRU鹈鹕算法优化卷积双向门控循环单元时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 MATLAB实现POA-CNN-BiGRU鹈鹕算法优化卷积双向…

Jenkins学习笔记6

开发者开发代码一般会使用IDE集成开发工具&#xff08;比如pycharm这种),那么使用pycharm开发的代码能否直接利用自动发布系统发布到业务服务器上呢&#xff1f; 答案是肯定的。 然后进行下测试&#xff1a; 那说明SSH免密是成功的。 将Pycharm修改为原来的界面&#xff0c;然…

抖音短视频矩阵系统搭建

企业在进行短视频矩阵运营时&#xff0c;搭建一个矩阵号是非常必要的。矩阵号可以绑定多个不同平台的账号&#xff0c;批量制作和定时发布短视频&#xff0c;提高企业的曝光量和粉丝互动。但是&#xff0c;如何搭建一个有效的短视频矩阵号呢&#xff1f;以下是几个关键步骤。 一…

STM32 NVIC中断优先级管理通过结构图快速理解

STM32 NVIC中断优先级管理通过结构图快速理解 &#x1f4d1;抢占优先级和响应优先级基本常识 &#x1f33f;抢占优先级的级别高于响应优先级。&#x1f33f;抢占优先级数值编号越小&#xff0c;所代表的优先级就越高&#xff1b;同理&#xff0c;响应优先级也是如此。&#x1…

为什么要选择Spring cloud Sentinel

为什么要选择Spring cloud Sentinel &#x1f34e;对比Hystrix&#x1f342;雪崩问题及解决方案&#x1f342;雪崩问题&#x1f342;.超时处理&#x1f342;仓壁模式&#x1f342;断路器&#x1f342;限流&#x1f342;总结 &#x1f34e;对比Hystrix 在SpringCloud当中支持多…

使用 FHE 实现加密大语言模型

近来&#xff0c;大语言模型 (LLM) 已被证明是提高编程、内容生成、文本分析、网络搜索及远程学习等诸多领域生产力的可靠工具。 大语言模型对用户隐私的影响 尽管 LLM 很有吸引力&#xff0c;但如何保护好 输入给这些模型的用户查询中的隐私 这一问题仍然存在。一方面&#xf…

《从菜鸟到大师之路 Redis 篇》

《从菜鸟到大师之路 Redis 篇》 &#xff08;一&#xff09;&#xff1a;Redis 基础理论与安装配置 Nosql 数据库介绍 是一种 非关系型 数据库服务&#xff0c;它能 解决常规数据库的并发能力 &#xff0c;比如 传统的数据库的IO与性能的瓶颈 &#xff0c;同样它是关系型数据…

Android 11.0 禁止二次展开QuickQSPanel设置下拉QSPanel高度

1.前言 在11.0的系统定制化需求中,在进行systemui的ui定制开发中,有些产品中有需求对原生systemui下拉状态栏中的二次展开QSPanel修改成 一次展开禁止二次展开,所以就需要修改QuickQSpanel的高度,然后在QuickQsPanel做定制,然后禁止二次展开就可以了 如图: 2.禁止二次展开…

32.3D文本旋转动画效果

特效 源码 index.html <!DOCTYPE html> <html> <head> <title>CSS 3D Text Rotation</title> <link rel="stylesheet" type="text/css" href="style.css"> </head> <body><div class=&quo…

C++实现观察者模式(包含源码)

文章目录 观察者模式一、基本概念二、实现方式三、角色四、过程五、结构图六、构建思路七、完整代码 观察者模式 一、基本概念 观察者模式&#xff08;又被称为模型&#xff08;Model&#xff09;-视图&#xff08;View&#xff09;模式&#xff09;是软件设计模式的一种。在…

5G通信与蜂窝模组之间的关系

5G通信是第五代移动通信技术的简称&#xff0c;它代表了一种新一代的无线通信技术标准。5G通信的主要目标是提供更高的数据传输速度、更低的延迟、更大的网络容量以及更可靠的连接&#xff0c;以支持各种新兴应用和服务&#xff0c;包括高清视频流、虚拟现实、物联网&#xff0…