Mybatis-Plus常用的查询方法--看这一篇就够了!!!
前言:
Mybatis-Plus作为Mybatis的增强,自己封装了很多简单还用的方法,来解脱自己写sql!
对于项目的搭建小编就不在说了,可以参考:
SpringBoot+Mybatis-Plus的入门搭建与配置测试
这样就可以跟小编站在同一起跑线了,咱们直接开始介绍方法的使用哦!!
步入正题:
方法一:根据主键id去查询单个结果 selectById
/**
* 方法一: 根据主键id去查询单个结果
* T selectById(Serializable id); ---参数为主键类型
*/
User user1 = userMapper.selectById(1);
/**
* 返回值结果
* {"id": 1,"name": "df","age": 222}
*/
方法二:查询多条数据库中的记录 selectList
/**
* 方法二: 查询多条数据库中的记录
* List<T> selectList(@Param("ew") Wrapper<T> queryWrapper);
* ---参数为Wrapper可以为空说明没有条件的查询
*/
List<User> users1 = userMapper.selectList(null);
/**
* 运行结果集
* [{"id": 1,"name": "df","age": 222},{"id": 2,"name": "wang","age": 22}]
*/
方法三:查询多条数据库中的记录---条件查询 selectList(wrapper)
/**
* 方法三:查询多条数据库中的记录---条件查询
* List<T> selectList(@Param("ew") Wrapper<T> queryWrapper);
*/
//首先构造QueryWrapper来进行条件的添加
QueryWrapper wrapper = new QueryWrapper();
wrapper.eq("id",1);//相当于where id=1
List<User> list = userMapper.selectList(wrapper);
/**
* 返回值结果
* {"id": 1,"name": "df","age": 222}
*/
福利赠送:条件构造器QueryWrapper常用方法
/**
*附加条件构造器QueryWrapper常用方法 ---这几个肯定够用了
*/
wrapper.eq("数据库字段名", "条件值"); //相当于where条件
wrapper.between("数据库字段名", "区间一", "区间二");//相当于范围内使用的between
wrapper.like("数据库字段名", "模糊查询的字符"); //模糊查询like
wrapper.groupBy("数据库字段名"); //相当于group by分组
wrapper.in("数据库字段名", "包括的值,分割"); //相当于in
wrapper.orderByAsc("数据库字段名"); //升序
wrapper.orderByDesc("数据库字段名");//降序
wrapper.ge("数据库字段名", "要比较的值"); //大于等于
wrapper.le("数据库字段名", "要比较的值"); //小于等于
方法四:根据主键的id集合进行多条数据的查询 selectBatchIds
/**
* 方法四: 根据主键的id集合进行多条数据的查询
* List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> idList);
* --条件为集合
*/
List list1 = Arrays.asList(1,2);
List<User> list2 = userMapper.selectBatchIds(list1);
/**
* 运行结果集
* [{"id": 1,"name": "df","age": 222},{"id": 2,"name": "wang","age": 22}]
*/
方法五:分页查询 selectPage
/**
* 方法五: 分页查询
* IPage<T> selectPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);
* ---参数为分页的数据+条件构造器
*/
IPage<User> page = new Page<>(1,2);//参数一:当前页,参数二:每页记录数
//这里想加分页条件的可以如方法三自己构造条件构造器
IPage<User> userIPage = userMapper.selectPage(page, null);
/**
* 运行结果集
* {"records":[{"id": 1,"name": "df","age": 222},{"id": 2,"name": "wang","age": 22}],
* "total": 0,"size": 2,"current": 1,"searchCount": true,"pages": 0 }
*/
小结:
谢谢大家的学习与观看,这五个是比较常用的方法,其他也有小编开发中没怎么用到,就不教学了。有问题留言交流,下期带来插入更新删除常用方法哦!!
Mybatis-Plus常用的查询方法--看这一篇就够了!!!的更多相关文章
- [转帖]nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件
nginx学习,看这一篇就够了:下载.安装.使用:正向代理.反向代理.负载均衡.常用命令和配置文件 2019-10-09 15:53:47 冯insist 阅读数 7285 文章标签: nginx学习 ...
- Java中的多线程=你只要看这一篇就够了
如果对什么是线程.什么是进程仍存有疑惑,请先Google之,因为这两个概念不在本文的范围之内. 用多线程只有一个目的,那就是更好的利用cpu的资源,因为所有的多线程代码都可以用单线程来实现.说这个话其 ...
- 鸿蒙应用程序Ability(能力)看这一篇就够
本节概述 什么是Ability Ability分类 Ability生命周期 Ability之间跳转 什么是Ability Ability意为能力,是HarmonyOS应用程序提供的抽象功能.在Andr ...
- 关于 Docker 镜像的操作,看完这篇就够啦 !(下)
紧接着上篇<关于 Docker 镜像的操作,看完这篇就够啦 !(上)>,奉上下篇 !!! 镜像作为 Docker 三大核心概念中最重要的一个关键词,它有很多操作,是您想学习容器技术不得不掌 ...
- JVM内存模型你只要看这一篇就够了
JVM内存模型你只要看这一篇就够了 我是一只孤傲的鱼鹰 让我们不厌其烦的从内存模型开始说起:作为一般人需要了解到的,JVM的内存区域可以被分为:线程栈,堆,静态方法区(实际上还有更多功能的区域,并且这 ...
- 【java编程】ServiceLoader使用看这一篇就够了
转载:https://www.jianshu.com/p/7601ba434ff4 想必大家多多少少听过spi,具体的解释我就不多说了.但是它具体是怎么实现的呢?它的原理是什么呢?下面我就围绕这两个问 ...
- 2019-5-25-win10-uwp-win2d-入门-看这一篇就够了
title author date CreateTime categories win10 uwp win2d 入门 看这一篇就够了 lindexi 2019-5-25 20:0:52 +0800 2 ...
- windows server 2019 域控批量新增不用,只看这一篇就够了,别的不用看
windows server 2019 域控批量新增不用,只看这一篇就够了,别的不用看 1. 新建excel表格 A B C D E 姓 名 全名 登录名 密码 李 四 李四 李四 test123!@ ...
- 什么是 DevOps?看这一篇就够了!
本文作者:Daniel Hu 个人主页:https://www.danielhu.cn/ 目录 一.前因 二.记忆 三.他们说-- 3.1.Atlassian 回答"什么是 DevOps?& ...
随机推荐
- noip模拟测试20
考试总结:这次考试,我非常真实地感觉到了自己能力的提高,具体来说,在之前的考试中,读完题之后我只会想到暴力的思路,甚至有的题连暴力都打不出来,但是这次在考场上我已经有了自己的一些想法,有了一个深入思考 ...
- Hotel 旅馆, 线段树查询,合并
C. Hotel 旅馆 内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 OIER最近的旅游计划,是到长春净月潭,享受那里的湖光山色, ...
- iTop安装 vm虚拟机、Linux、centos7安装itop 2.6.1
itop安装流程,是我基于下面两位博主发布的文章整理出来的,欢迎大家学习,如有错误之处请大家留言指出我看到之后及时更新.谢谢 https://blog.csdn.net/qq_23565543/art ...
- 正则表达式-固定XML格式提取内容
(?<=(<(?<a>([A-Za-z]*?))>)).*?(?=(</\k<a>>))
- PAT甲级 1112 Stucked Keyboard
题目链接:https://pintia.cn/problem-sets/994805342720868352/problems/994805357933608960 这道题初次写的时候,思路也就是考虑 ...
- 实战爬取某网站图片-Python
直接上代码 1 #!/usr/bin/python 2 # -*- coding: UTF-8 -*- 3 from bs4 import BeautifulSoup 4 import request ...
- HCNA Routing&Switching之DHCP服务
前文我们了解了STP的端口状态.计时器以及端口状态切换和网络拓扑变化相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15140672.html:今天我们 ...
- Linux的磁盘管理和文件系统
一.磁盘结构 1.1.硬盘的物理结构 盘头:硬盘有多个盘片,每盘片2面 磁头:每面一个磁头 1.2.硬盘的数据结构 扇区:盘片被分为多个扇形区域,每个扇区存放512字节的数据,硬盘的最小存储单位 磁道 ...
- 适配Android4.4~Android11,调用系统相机,系统相册,系统图片裁剪,转换文件(对图片进行上传等操作)
前言 最近Android对于文件的许多方法进行了修改,网络上又没有对Android4到Android11关于系统相机.系统相册和系统裁剪的适配方案,我花了几天事件总结了一下,先上源码 DEMO源码 先 ...
- 解决java种mysql中文乱码问题
乱码问题原因有多种,其中有一种是由于MySQL默认使用 ISO-8859-1 ( 即Latin1 ) 字符集,而JAVA内部使用Unicode编码,因此在JAVA中向MYSQL数据库插入数据时,或者读 ...