MybatisPlus核心功能——实现CRUD增删改查操作 (包含条件构造器)

本文详述了如何使用MybatisPlus进行CRUD操作,包括条件构造器的使用,插入、更新、查询和删除接口的实现。重点介绍了Wrapper类在条件查询中的应用,以及Mapper和Service层的不同CRUD接口。此外,还提到了SaveOrUpdate方法的逻辑以及Chain模式的优势。
摘要由CSDN通过智能技术生成

🚀 优质资源分享 🚀

学习路线指引(点击解锁) 知识定位 人群定位
🧡 Python实战微信订餐小程序 🧡 进阶级 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
💛Python量化交易实战💛 入门级 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

CRUD

官方文档:https://baomidou.com/
(建议多看看官方文档,每种功能里面都有讲解)【本文章使用的mybatisplus版本为3.5.2】

条件构造器

一般都是用service层的方法,因为比mapper层的全。十分重要:Wrapper 记住查看输出的SQL进行分析

相当于创建一个构造器对象,然后讲需要查询or更新的条件写在里面,最后打包给mapper or service层的插入、更新方法

下图是Wapper的子类,QueryWrapperUpdateWrapper是一般的Wrapper,AbstractLambdaWrapper 是lambda语法糖的链式操作(两者选择一种使用即可)

image

下图是wrapper的条件方法,就不一一介绍了,下面举了六个就基本例子
image

1、测试一

copy@Test
public void testWrapper1() {
    //参数是一个wrapper ,条件构造器,和刚才的map对比学习!
    //查询name不为空,email不为空,age大于18的用户
    QueryWrapper wrapper = new QueryWrapper<>();
 wrapper
 .isNotNull("name")
 .isNotNull("email")
 .ge("age",18);
 List userList = userMapper.selectList(wrapper);
 userList.forEach(System.out::println);
}

测试二

copy@Test
public void testWrapper2() {
    //查询name=wsk的用户
    QueryWrapper wrapper = new QueryWrapper<>();
 wrapper.eq("name","wsk");
 //查询一个数据selectOne,若查询出多个会报错
 //Expected one result (or null) to be returned by selectOne(), but found: *
 //若出现多个结果使用list或map
 User user = userMapper.selectOne(wrapper);//查询一个数据,若出现多个结果使用list或map
 System.out.println(user);
}

测试三

copy@Test
public void testWrapper3() {
    //查询age在10-20之间的用户
    QueryWrapper wrapper = new QueryWrapper<>();
 wrapper.between("age", 10, 20);//区间
 Integer count = userMapper.selectCount(wrapper);//输出查询的数量selectCount
 System.out.println(count);
}

测试四

copy@Test
public void testWrapper4() {
    //模糊查询
    QueryWrapper wrapper = new QueryWrapper<>();
 wrapper
 .notLike("name","s")
 .likeRight("email","qq");//qq% 左和右?
 List> maps = userMapper.selectMaps(wrapper);
 maps.forEach(System.out::println);
}

测试五

copy@Test
public void testWrapper5() {
    //模糊查询
    // SELECT id,name,age,email,version,deleted,create\_time,updat
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

[虚幻私塾】

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值