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


    🚀 优质资源分享 🚀

    学习路线指引(点击解锁) 知识定位 人群定位
    🧡 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);
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    测试二

    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);
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    测试三

    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);
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    测试四

    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);
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    测试五

    copy@Test
    public void testWrapper5() {
        //模糊查询
        // SELECT id,name,age,email,version,deleted,create\_time,updat
    • 1
    • 2
    • 3
  • 相关阅读:
    韦东山linux驱动开发学习【常更】
    如何把MapGIS的区文件转为ArcGIS的SHAPE面文件
    『第八章』进击的雨燕:Combine 框架
    Redisson实现分布式锁的实战案例-锁单key-锁多key-看门狗
    【从零开始游戏开发】静态资源优化 | 全面总结 |建议收藏
    戏说领域驱动设计(廿四)——资源库
    Redux(mvc、flux、react-redux)
    使用 Pinia 轻松实现复杂的 Vue 3 状态管理
    淘宝API接入说明,Onebound数据
    学习视频剪辑:巧妙运用中画、底画,制作画中画,提升视频效果
  • 原文地址:https://blog.csdn.net/m0_56069948/article/details/126446680