Mybatis-Plus(二)--Mybatis-Plus方法大全

通用CRUD大全(Mybatis-Plus为我们提供了哪些操作)


还有在mybatis中遇到列名和属性名不一致等等的情况,在mybatis中xml中声明解决,在mybatis-plus中也都有对应的解决。

 1.插入操作


//插入一条记录
//参数entity是实体对象
int insert(T entity)
【1】设置id生成策略
数据写入数据库,但是id并不是我们希望的自增长,而是随机生成了id的值写入到了数据库。
我们就要设置id生成策略来解决这个问题。
MP支持的id策略:

package com.baomidou.mybatisplus.annotation;
//生成ID类型的枚举类
public enum IdType {
    //数据库id自增
    AUTO(0),
    //该类型为未设置为主键类型
    NONE(1),
    //用户输入ID,该类型可以通过自己注册自动填充插件来进行填充
    INPUT(2),
    //以下两种类型,只有当插入对象ID为空,才自动填充,全局唯一ID
    //其实我也不知道什么意思
    ASSIGN_ID(3),
    ASSIGN_UUID(4);


    private final int key;
    private IdType(int key) {
        this.key = key;
    }
    public int getKey() {
        return this.key;
    }
}

用法是在实体类的对象id属性上添加注解:

@TableId(type = IdType.AUTO)
private Long id;

【2】@TableField
(1)对象中的属性名和字段名不一致的问题(非驼峰)

@TableField(value = "email") //解决数据库中字段名与属性不一致
private String mail;

(2)对象中的属性字段在表中不存在的问题

@TableField(exist = false)
private String address; //在数据库表中是不存在的

(3)字段不加入查询字段

@TableField(exist = false)
private String address; //在数据库表中是不存在的

2.更新操作

在Mybatis-Plus中更新操作有2种,一种是根据id更新,另一种是根据条件更新。

【1】根据id更新


定义:
//根据ID修改
//@param entity 实体对象
int updateById(T entity);

使用:

//根据id更新,更新不为null的字段
userMapper.updateById(user);

【2】根据条件更新


定义:
//根据whereEntity条件,更新记录
//@param entity  实体对象(set条件值,可以为null)
//@param updatewrapper  实体对象封装操作类(可以为null,里面的entity用于生成where语句)
int update(T entity,Wrapper<T> updateWrapper);

使用:
例1:

User user=new User();
user.setAge(22);//更新的字段

//更新的条件
QueryWrapper<User> wrapper=new QueryWrapper<>();
wrapper.eq("id",6);

//执行更新操作
int result=this.userMapper.update(user,wrapper);
System.out.println("result = "+result);

例2:

//更新的条件及字段
updateWrapper<User> wrapper=new UpdateWrapper<>();
wrapper.eq("id",6).set("age",23);

//执行更新操作
int result=this.userMapper.update(null,wrapper);
System.out.println("result = "+result);

3.删除操作

1.根据id删除

【1】deleteById

定义:int deleteById(Serializable id); 

int result=this.userMapper.deleteById(6L);//Long类型的6
System.out.println("result = "+result);

【2】deleteBatchIds
定义:int deleteBatchIds(Collection<? extends Serializable> idList);

//根据id集合批量删除
int result=this.userMapper.deleteBatchIds(Arrays.asList(1L,10L,20L));

2.根据条件删除

【1】deleteByMap

定义:int deleteByMap(Map<String,Object> columnMap);

Map<String,Object> columnMap=new HashMap<>();
columnMap.put("age",20);
columnMap.put("name","张三");

//将columnMap中的元素设置为删除的条件,多个之间为and关系
int result=this.userMapper.deleteByMap(columnMap);
System.out.println("result = "+result);

【2】delete
定义:int delete(Wrapper<T> wrapper);

User user=new User();
user.setAge(20);
user.setName("张三");
//将实体对象进行包装,包装为操作条件
QueryWrapper<User> wrapper =new QueryWrapper<>(User);

int result=this.userMapper.delete(wrapper);

4.查询操作

1.根据id查询单条数据

定义:T selectById(Serializable id);

//根据id查询数据
User user=this.userMapper.selectById(2L);

2.根据id集合批量查询

定义://根据ID批量查询
List<T> selectBatchIds(Collection<? extends Serializable> idList);

//根据id集合批量查询
List<User> users=this.userMapper.selectBatchIds(Arrays.asList(2L,3L,10L));
for(User user:users){
    System.out.println(user);
}

3.根据条件查询单条数据

定义:T selectOne(wrapper<T> queryWrapper);

QueryWrapper<User> wrapper =new QueryWrapper<User>();
wrapper.eq("name","李四");
//根据条件查询一条数据,如果结果超过一条会报错
User user = this.userMapper.selectOne(wrapper);

4.根据条件查询多条数据

定义:List<T> selectList(wrapper<T> queryWrapper);

QueryWrapper<User> wrapper=new QueryWrapper<User>();
wrapper.gt("age",23);//年龄大于23岁
//根据条件查询数据
List<User> users=this.userMapper.selectList(wrapper);

5.根据条件查询总记录数

定义:Integer selectCount(Wrapper<T> queryWrapper);

QueryWrapper<User> wrapper=new QueryWrapper<User>();
wrapper.gt("age",23);//年龄大于23岁
//根据条件查询数据条数
Integer count=this.userMapper.selectCount(wrapper);

6.分页查询

定义:IPage<T> selectPage(IPage<T> page,Wrapper<T> queryWrapper);
例:
配置分页插件:

@Configuration
@MapperScan("cn.itcast.mp.mapper")
public class MybatisPlusConfig {
    //分页插件
    @Bean
    public PaginationInnerInterceptor paginationInnerInterceptor() {
        return new PaginationInnerInterceptor();
    }
}

测试:

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest
public class TestMybatisSpringBoot {
    @Autowired
    private UserMapper userMapper;
    @Test
    public void testSelectPage(){
        QueryWrapper<User> wrapper=new QueryWrapper<User>();
        wrapper.gt("age",20);
        Page<User> page=new Page<>(1,1);
        //根据条件查询数据
        IPage<User> iPage=this.userMapper.selectPage(page,wrapper);

        System.out.println("数据总条数:"+iPage.getTotal());
        System.out.println("总页数:"+iPage.getPages());
        List<User> users=iPage.getRecords();
        for(User user:users){
            System.out.println("user = "+user);
        }
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于单片机的智能点滴速度输液液体检测

目 录 摘 要...................................................................................................................... I ABSTRACT.......................................................................................................... II 第…

【机器学习】吴恩达课程1-Introduction

一、机器学习 1. 定义 计算机程序从经验E中学习&#xff0c;解决某一任务T&#xff0c;进行某一性能P&#xff0c;通过P测定在T上的表现因经验E而提高。 2. 例子 跳棋程序 E&#xff1a;程序自身下的上万盘棋局 T&#xff1a;下跳棋 P&#xff1a;与新对手下跳棋时赢的概…

离线数据仓库

一、数据仓库 1.数据仓库的概念 1)数据仓库的特点: 面向主题的:对数据进行整合、分析和归类的抽象集成的:将不同数据源的数据(业务数据、外部系统数据、埋点日志)经过统一编码、规范命名、字段类型转换等操作,整合到仓库相对稳定的:根据业务场景实时更新、一般会被长…

C语言-ubuntu下的命令

目录 linux命令 【1】打开关闭终端 【2】终端 【3】ls命令 【4】cd 切换路径 【5】新建 【6】删除 【7】复制 【8】移动 【9】常用快捷键 【10】vi编辑器 【11】简单编程步骤 任务&#xff1a; linux命令 【1】打开关闭终端 打开终端&#xff1a; 1. 直接点击 …

代码随香录day21

235. 二叉搜索树的最近公共祖先 本题思路&#xff1a; 还是要利用二叉搜索树的特性&#xff0c;中序遍历为有序数组。如果pq两个节点都小于root&#xff0c;那么最近公共祖肯定是在他的左子树&#xff0c;如果都大于那么&#xff0c;肯定就在右子树。然后直接return root 代码…

Sentinel的线程隔离和熔断降级

上一节整理了Sentinel的限流&#xff0c;限流可以降低微服务的负载&#xff0c;避免因为高并发而故障&#xff0c;进而传递给其他相关服务而引发服务雪崩。以上仅为避免服务故障&#xff0c;而当某个服务真正故障时&#xff0c;如何处理才能防止服务雪崩&#xff1f; ⇒ Sentin…

Azure Kinect DK 在设备管理器找不到此设备

参考 Azure Kinect DK 在设备管理器找不到此设备_Thomas_yx的博客-CSDN博客 type-c------------------type-c 接电脑&#xff0c;数据传输 圆------------------usb 电脑线

Spark(29):Spark内存管理

目录 0. 相关文章链接 1. 堆内和堆外内存规划 1.1. 堆内内存 1.2. 堆外内存 2. 内存空间分配 2.1. 静态内存管理 2.2. 统一内存管理 3. 存储内存管理 3.1. RDD 的持久化机制 3.2. RDD的缓存过程 3.3. 淘汰与落盘 4. 执行内存管理 4.1. Shuffle Write 4.2. Shuffl…

【STM32】使用HAL库对ULN2003控制28BYJ-48步进电机

步进电机是将电脉冲信号转变为角位移或线位移&#xff0c;通过控制施加在电机线圈上的电脉冲顺序、频率和数量&#xff0c;可以控制步进电机的转向、速度和旋转角度。 配合以直线运动执行机构(螺纹丝杆)或齿轮箱装置&#xff0c;更可以实现更加复杂、精密的线性运动控制要求。…

HTTP进化史:从HTTP1的简单到HTTP3的强大

文章目录 &#x1f4c8;I. HTTP1⚡A. 基本特点⚡B. 特点⚡C. 优缺点 &#x1f4c8;II. HTTP2⚡A. 基本特点⚡B. 特点⚡C. 优缺点 &#x1f4c8;III. HTTP3⚡A. 基本特点⚡B. 特点⚡C. 优缺点 &#x1f4c8;IV. 总结&#x1f4c8;附录&#xff1a;「简历必备」前后端实战项目&am…

【动手学深度学习】pytorch-参数管理

pytorch-参数管理 概述 我们的目标是找到使损失函数最小化的模型参数值。 经过训练后&#xff0c;我们将需要使用这些参数来做出未来的预测。 此外&#xff0c;有时我们希望提取参数&#xff0c;以便在其他环境中复用它们&#xff0c; 将模型保存下来&#xff0c;以便它可以在…

回归预测 | MATLAB实现WOA-CNN鲸鱼算法优化卷积神经网络的数据多输入单输出回归预测

回归预测 | MATLAB实现WOA-CNN鲸鱼算法优化卷积神经网络的数据多输入单输出回归预测 目录 回归预测 | MATLAB实现WOA-CNN鲸鱼算法优化卷积神经网络的数据多输入单输出回归预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 回归预测 | MATLAB实现WOA-CNN鲸鱼算法优化卷积…

matlab重名函数调用踩坑记录

我新安装了matlab的robotics toolbox&#xff0c;然而调用的rotx不是我想要的函数。 我上网查了一下资料&#xff0c;知乎和csdn有相关的回答&#xff0c;但是我试了一下还是不行。它们的方法是移除路径再添加路径避免函数的冲突。相关方法放在文末的相关参考1 2。这里建议先用…

上门服务小程序|上门家政小程序开发

随着现代生活节奏的加快和人们对便利性的追求&#xff0c;上门家政服务逐渐成为了许多家庭的首选。然而&#xff0c;传统的家政服务存在着信息不透明、服务质量不稳定等问题&#xff0c;给用户带来了困扰。为了解决这些问题&#xff0c;上门家政小程序应运而生。上门家政小程序…

Zookeeper集群

Zookeeper集群 一、Zookeeper 概述Ⅰ、Zookeeper 定义&#xff1a;Ⅱ、Zookeeper 工作机制Ⅲ、Zookeeper 特点Ⅳ、Zookeeper 数据结构Ⅴ、Zookeeper 应用场景Ⅵ、Zookeeper 选举机制 二、部署 Zookeeper 集群Ⅰ、安装前准备Ⅱ、安装Zookeeper 三、部署kafka 集群Ⅰ、下载安装包…

设计模式07-责任链模式

责任链模式属于行为设计模式&#xff0c;常见的过滤器链就是使用责任链模式设计的。 文章目录 1、真实开发场景的问题引入2、责任链模式讲解2.1 核心类及类图2.2 基本代码 3、利用构建者模式解决问题4、责任链模式的应用实例5、总结5.1 解决的问题5.2 使用场景5.3 优缺点 1、真…

【观察】杉数科技:释放智能决策“乘数效应”,驱动智能制造高质量增长

毫无疑问&#xff0c;中国制造业在时代背景与国家政策的双重驱动下&#xff0c;正加速向数智化转型&#xff0c;而以数据驱动的智能决策也正成为制造业资源优化配置的“利器”&#xff0c;通过端到端的数据深度感知与决策优化&#xff0c;显然能够将工业和制造业的数据价值发挥…

RT-Thread 学习-Env开发环境搭建(一)

Env是什么 Env 是 RT-Thread 推出的开发辅助工具&#xff0c;针对基于 RT-Thread 操作系统的项目工程&#xff0c;提供编译构建环境、图形化系统配置及软件包管理功能。 其内置的 menuconfig 提供了简单易用的配置剪裁工具&#xff0c;可对内核、组件和软件包进行自由裁剪&…

C++基础算法离散化及区间合并篇

&#x1f4df;作者主页&#xff1a;慢热的陕西人 &#x1f334;专栏链接&#xff1a;C算法 &#x1f4e3;欢迎各位大佬&#x1f44d;点赞&#x1f525;关注&#x1f693;收藏&#xff0c;&#x1f349;留言 主要讲解了双指针&#xff0c;位运算&#xff0c;离散化以及区间合并。…

02 QPushButton的基本使用

Tips: 在使用控件的时候如果没有智能提示&#xff0c;可能是没有包含头文件 在运行时&#xff0c;报【invalid use of xxx】可能是没有包含相关头文件 如果出现中文乱码&#xff1a;设置编译器的编码格式为UTF-8 本节主要包含创建一个按钮控件、显示按钮、设置按钮的父窗口、设…