MybatisPlus的使用

news2024/10/5 19:20:03

一.  关于注解的使用,官方地址:

注解 | MyBatis-PlusMyBatis-Plus 官方文档https://baomidou.com/pages/223848/#tablename

 

1.关于@TableName的使用

 假设我们不加@TableName("tbl_employee")的话,那么数据库中的表名和类名相同的话,那么是ok的,如果不同,为我们就必须加上@TableName这个注解。

2.关于@TableId的使用

这是一个主键注解,用在实体类主键字段上

如果我们不加@TableId注解的话,mp 会自动识别pojo类中名为id的属性,如果名字叫id就会当做是主键,

全局生成策略有几种,我们最常用的就是自增长的类型的

除了在每个实体类上的id属性字段上加上@TableId

还有一种方式:

就是将id属性字段上加上@TableId去掉

之后再核心配置文件中加入以下:

3.@TableField注解的使用

当实体类属性名和数据库中标的字段名不一致的情况下,使用该注解可以设置对应的映射关系。

@TableName("sys_user")
public class User {
    @TableId
    private Long id;
    @TableField("nickname")
    private String name;
    private Integer age;
    private String email;
}

 如果有一个字段不是表中的字段

可以使用:

@TableField(exist = false)
private String genderName;

 二.  关于MP的分页使用

1.在配置类中加入分页插件,不加分页插件的话,分页不好用

 // 最新版
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }

2.在Service中使用

    @Test
    public void queryPage(){
        IPage<Desc> page = new Page<Desc>(1,5);
        IPage<Desc> descIPage = descService.page(page);
        System.out.println("一共多少页?"+descIPage.getPages());
        System.out.println("当前第几页?"+descIPage.getCurrent());
        System.out.println("一共多少条数据?"+descIPage.getTotal());
        System.out.println("一页多少条数据?"+descIPage.getSize());
        System.out.println(descIPage.getRecords());
    }

ps:

自定义的 mapper#method 使用分页

IPage<UserVo> selectPageVo(IPage<?> page, Integer state);
// or (class MyPage extends Ipage<UserVo>{ private Integer state; })
MyPage selectPageVo(MyPage page);
// or
List<UserVo> selectPageVo(IPage<UserVo> page, Integer state);

<select id="selectPageVo" resultType="xxx.xxx.xxx.UserVo">
    SELECT id,name FROM user WHERE state=#{state}
</select>

如果返回类型是 IPage 则入参的 IPage 不能为null,因为 返回的IPage == 入参的IPage; 如果想临时不分页,可以在初始化IPage时size参数传 <0 的值;
如果返回类型是 List 则入参的 IPage 可以为 null(为 null 则不分页),但需要你手动 入参的IPage.setRecords(返回的 List);
如果 xml 需要从 page 里取值,需要 page.属性 获取

三.  关于MP中的条件构造器Wrapper的使用

在学习MP的过程中,之前我们进行数据库操作的时候最多是用map进行对等条件的筛选

那么怎么进行更复杂的筛选呢?比如条件筛选模糊匹配等等?那么就是用条件构造器

 

    @Test
    public void queryWrapper(){
        QueryWrapper<Desc> wrapper = new QueryWrapper<>();
        QueryWrapper<Desc> eq = wrapper.select("id", "name_desc").eq("name_desc", "小兔");
        List<Desc> list = descService.list(eq);
        System.out.println(list);
    }

注意:此处的map-underscore-to-camel-case: true这个属性需要设置成true

不设置成true也可以

写成如下:

 @Test
    public void queryWrapper(){
        QueryWrapper<Desc> wrapper = new QueryWrapper<>();
        QueryWrapper<Desc> eq = wrapper.select("id", "name_desc as nameDesc").eq("name_desc", "小兔");
        List<Desc> list = descService.list(eq);
        System.out.println(list);
    }

between

@Test
public void queryWrapperBetween(){
    QueryWrapper<Desc> wrapper = new QueryWrapper<>();
    QueryWrapper<Desc> eq = wrapper.between("id",2L,10L);
    List<Desc> list = descService.list(eq);
    System.out.println(list);
}

updateWrapper

 @Test
    public void updateWrapper01(){
        UpdateWrapper<Desc> wrapper = new UpdateWrapper<>();
        wrapper.set("name_desc","小兔子")/*.eq("id","2")*/
                /*.in("id","3","4","5");*/
                .between("id",9L,15L);
        boolean update = descService.update(wrapper);
        System.out.println(update);
    }

lambda方式

LambdaQueryWrapper

// 以上都是硬编码方式,不想用硬编码的方式,那就使用lambda表达式的方式

    @Test
    public void queryWrapperLambada(){
        QueryWrapper<Desc> wrapper = new QueryWrapper<>();
        LambdaQueryWrapper<Desc> eq = wrapper.lambda().select(Desc::getId,Desc::getNameDesc).eq(Desc::getId, 2L);
        Desc one = descService.getOne(eq);
        System.out.println(one);
    }

LambdaUpdateWrapper

@Test
public void updateWrapperLambada(){
    UpdateWrapper<Desc> wrapper = new UpdateWrapper<>();
    wrapper.lambda().set(Desc::getNameDesc,"小兔子乖乖")
            .between(Desc::getId,12L,15L);
    boolean update = descService.update(wrapper);
    System.out.println(update);
}

未完待续...

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

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

相关文章

Qt下拉菜单

1&#xff0c;QComboBox 2&#xff0c;setMenu()---设置下拉菜单 AI对话未来丨智能写作对话: setMenu()是QWidget类的一个成员函数&#xff0c;在Qt中用于将一个菜单作为一个控件的下拉菜单设置。具体来说&#xff0c;它会把相应的菜单对象与该控件关联&#xff0c;并在控件上…

Mysql8.0为什么取消了缓存查询的功能

首先我们介绍一下MySQL的缓存机制 【MySQL缓存机制】简单的说就是缓存sql文本及查询结果&#xff0c;如果运行完全相同的SQL&#xff0c;服务器直接从缓存中取到结果&#xff0c;而不需要再去解析和执行SQL。 但如果表中任何数据或是结构发生改变&#xff0c;包括INSERT、UPD…

问道管理:放量打拐什么意思?常见的放量打拐三种形态?

成交量一直是股票交易中比较重要的目标&#xff0c;那么&#xff0c;放量打拐是什么意思&#xff1f;常见的放量打拐三种形状是什么&#xff1f;下面问道管理为我们预备了相关内容&#xff0c;以供参阅。 放量打拐什么意思&#xff1f; 放量是指股票成交量与前几个交易日比较显…

隐私文件夹怎么加密?隐私文件夹加密方法

在个人电脑中&#xff0c;我们经常会将一些个人隐私存放在电脑文件夹中&#xff0c;这些文件夹都需要加密保护。那么&#xff0c;隐私文件夹该怎么加密呢&#xff1f;下面我们就来了解一下吧。 超级秘密文件夹 隐私数据存放在文件夹中&#xff0c;最怕的就是被其他人发现。而如…

迅镭激光中标全球集装箱行业龙头中集集团10家子公司集采项目!

迅镭激光中标喜报频传!继连续中标工程机械、钢构、船舶、电力电气、新能源等多个行业龙头企业后&#xff0c;近日再次中标全球集装箱行业龙头中集集团(CIMC)&#xff0c;这与迅镭激光坚持高端、注重技术引领、十五年的技术沉淀和口碑积累密不可分。 日前&#xff0c;中集集团20…

如何使用ChatGPT创作一个小说式的虚构的世界

世界构建也许是小说写作中最重要的一环&#xff0c;但也可能非常耗时。让ChatGPT加快这一过程吧。 写小说最棒的一点就是有机会从零开始创造一个新世界。你可以创造超凡脱俗的景观&#xff0c;赋予人物魔法。神话故事可以存在于你小说中的现实世界&#xff0c;而传统可以帮助你…

gazebo仿真ros2两轮差速小车没有控制的情况下缓慢移动后退

最近在做一款2轮差速的机器人小车&#xff0c;在做gazebo仿真的时候&#xff0c;发现小车一直在缓慢的后退&#xff0c;一边后退一边缓慢拐弯。 环境&#xff1a;ros2 foxy gazebo-11 小车xacro模型代码 <?xml version"1.0"?> <robot name"jtb…

华为OD机试 - 查找接口成功率最优时间段 - 回溯(Java 2023 B卷 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷&#…

【图书推荐 | 测试】—《测试设计思想》

前言 随着科技的不断发展&#xff0c;互联网的不断进步&#xff0c;日益出现了一种趋势&#xff1a;测试设计将成为一种跨领域的综合性工作&#xff0c;测试者将成为一种跨领域的通用型人才。由此清华大学出版社推出了一本名为《测试设计思想》的书籍&#xff0c;由知名专家周…

分析Flink,源和算子并行度不一致时,运行一段时间后,看似不再继续消费的问题,提供解决思路。

文章目录 背景分析 问题来了比较一开始的情况解决方式 背景 之前有分析过一次类似问题&#xff0c;最终结论是在keyby之后&#xff0c;其中有一个key数量特别庞大&#xff0c;导致对应的subtask压力过大&#xff0c;进而使得整个job不再继续运作。在这个问题解决之后&#xff…

数据分析15——office中的Excel基础技术汇总

0、前言&#xff1a; 这部分总结就是总结每个基础技术的定义&#xff0c;在了解基础技术名称和定义后&#xff0c;方便对相关技术进行检索学习。笔记不会详细到所有操作都说明&#xff0c;但会把基础操作的名称及作用说明&#xff0c;可自行检索。本文对于大部分读者有以下作用…

火山引擎DataLeap:助力PICO落地数据流程规范,提升开发效率

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 作为目前中国市场领跑的头部XR品牌之一&#xff0c;字节跳动旗下的PICO已经拥有了超百万客户。 过去一年&#xff0c;PICO在XR场景中不断建设和发力&#xff0c;为运…

更好的 3D 网格,从重建到生成式 AI

推荐&#xff1a;使用 NSDT场景编辑器 助你快速搭建可二次编辑的3D应用场景 这些生成的 3D 模型通常提取为标准三角形网格。网格表示提供了许多好处&#xff0c;包括支持现有软件包、高级硬件加速和支持物理仿真。但是&#xff0c;并非所有网格都是平等的&#xff0c;这些优势只…

在南非发现地球上最古老冰川的证据

古老的冰川暗示着太古代地球在某些方面可能与我们所处的时代相似。 29 亿年前的地球可能有像阿根廷南部冰川国家公园的佩里托莫雷诺冰川这样的冰川。图片来源&#xff1a; Martin St-Amant/维基百科 《地球化学展望快报》上发表的一项 新研究报告称&#xff0c;早在 30 亿年前…

离心机使用操作说明(记录备忘)

关于离心机的使用步骤做一简单记录 1.配准 2.装载&#xff08;对称性放置&#xff09; 3.确认&#xff08;装载完毕之后确认&#xff0c;轻轻转动&#xff09; 4.盖锅盖 5.关闭主盖 6.设置参数 7.运行 开始加速之后 转速会持续增加至设定值&#xff0c;离心结束后&#xff0c…

Python functools module 的介绍与应用

Python functools module 的介绍与应用 functools module lru_cache from functools import lru_cache import timelru_cache(maxsizeNone) # 设置缓存大小为无限制 def my_function(x):for i in range(1000):x xfor j in range(100):x xreturn x# 第一次调用函数&#xff…

概念解析 | 群像素激光雷达

群像素激光雷达技术解析 注1:本文系“概念解析”系列之一,致力于简洁清晰地解释、辨析复杂而专业的概念。本次辨析的概念是:群像素激光雷达技术。 1. 背景介绍 激光雷达作为一种主动式激光探测技术,通过发射脉冲激光并接收其反射回波信号,来获取目标距离和其他信息,在军事侦察…

收支明细高效管理,轻松查看和统计时间段内的开销收支明细!

亲爱的用户们&#xff0c;您是否经常需要查看某一时间段内的所有开销和收支明细&#xff0c;并进行自动统计和分析&#xff1f;现在&#xff0c;我们为您带来一款智能财务管家&#xff0c;让您轻松管理财务&#xff01; 首先&#xff0c;我们要进入晨曦记账本主页面&#xff0…

【c语言】通讯录(动态版+文件+背景音乐)含源码

开饭了&#xff0c;之前写的通讯录&#xff0c;是否会有人觉得申请1000人的空间是不是有点用不上呀&#xff0c;怎么才能做到要多少申请多少个呢&#xff1f;&#xff1f;我们学完动态内存管理&#xff0c;和文件的相关操作&#xff0c;终于可以继续完善我们的通讯录了 船新版本…