Mybatis-Plus的Service方法使用 之 泛型方法default <V> List<V> listObjs(Function<? super Object, V> mapper)
首先 我们先看到的这个方法入参是:Function<? super Object , V> mapper ,这是jdk1.8为了统一简化书写格式引进的函数式接口 。
简单 解释一下我对Function函数的理解 , 就以上面的写法为例,可以看到Function函数要传入两个类型:
1. ? super Object 这个类型限制了下限 , 即 传入的类型必须是Object的超类,或者是Object ,所以 ,函数的第一个类型必然是 Object类型 ,后面会说为什么会是Object类型
2. V 没有限制泛型的上下边界 , 所以可以为任何类型
3. 每个函数式接口的典型特点就是有且仅有一个可以实现的接口 , Function也不例外;看下接口部分源码: @FunctionalInterface
public interface Function<T, R> {
R apply(T t);
...
}
4. 看到这里应该明白,这个接口做的就是类型之间 T和R 的转换 ,传入T类型 ,返回R类型。
5. 那么上面的Function<? super Object, V>写法 就是说 传入Object类型 , 返回 V 类型 。 对Function接口,就说这么多 ,这里不做详细解释 ,想了解可以去自行搜索。 对于mp的业务方法listObjs()方法 ,我们只讨论它的泛型方法 ,下面是方法介绍
mp官网接口介绍 // 查询全部记录
1. <V> List<V> listObjs(Function<? super Object, V> mapper);
// 根据 Wrapper 条件,查询全部记录
2. <V> List<V> listObjs(Wrapper<T> queryWrapper, Function<? super Object, V> mapper); 接口源码 1. default List<Object> listObjs() {
return this.listObjs(Function.identity());
} 2. default <V> List<V> listObjs(Function<? super Object, V> mapper) {
return this.listObjs(Wrappers.emptyWrapper(), mapper);
} 3. default List<Object> listObjs(Wrapper<T> queryWrapper) {
return this.listObjs(queryWrapper, Function.identity());
} 4. default <V> List<V> listObjs(Wrapper<T> queryWrapper, Function<? super Object, V> mapper) {
return (List)this.getBaseMapper().selectObjs(queryWrapper).stream().filter(Objects::nonNull).map(mapper).collect(Collectors.toList());
} 可以看到接口源码中 方法2 调用了方法4 方法4的意义是 :
this.getBaseMapper().selectObjs(queryWrapper):
拿到BaseMapper,再调用它的selectObjs方法传入queryWrapper条件,查出数据list,
stream().filter(Objects::nonNull).map(mapper).collect(Collectors.toList()):
再利用流处理,过滤掉空值,筛选出mapper类型的数据,重新组成一个集合。就得到了我们所需要的List<V>数据。
这个V类型就是我们上面所说的Function中所传的泛型V,就是我们想要转换的类型。 接下来看一下我们在Service业务方法中 对Function的方法实现以及对listObjs()方法的调用。 1.先实例化出Function接口 ,实现apply接口,进行类型转换,
其中Object类型的参数是我们实体类中使用Mp的@TableId注解标注的属性,
## 由于主键属性的类型不定,所以mp只能定为Object类型来限制传参。 ##
如果没有标注注解,则根据属性名对应数据库表的字段进行匹配查找(参数一般都是主键id,除非你使用@TableId注解标注了其他字段)
Function<Object,Long> function = new Function<Object, Long>() {
@Override
public Long apply(Object id) {
//进行一系列转换操作 ,最终返回我们所需要的类型V , 这里只做简单演示。
return Long.valueOf(id.toString());
}
};
2.调用listObjs(queryWarpper,function)方法,这里queryWrapper就不做介绍。 List<Long> longs1 = listObjs(null, function); 3.经过Function的处理我们会得到表中数据的所有主键做组成的list集合。 另两种写法 , 和上面的写法一致 ,推荐最后一种。 //匿名类写法
List<Long> longs = listObjs(null, new Function<Object, Long>() {
@Override
public Long apply(Object id) {
//进行一系列转换操作 ,最终返回我们所需要的类型V , 这里只做简单演示。
return Long.valueOf(id.toString());
}
});
//简写
List<Long> longs = listObjs(null, a ->{
return Long.valueOf(a.toString());
});
Mybatis-Plus的Service方法使用 之 泛型方法default <V> List<V> listObjs(Function<? super Object, V> mapper)的更多相关文章
- MyBatis学习--mybatis开发dao的方法
简介 使用Mybatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper接口开发方法. 主要概念介绍: MyBatis中进行Dao开发时候有几个重要的类,它们是SqlSessionFac ...
- 四 mybatis开发dao的方法
mybatis开发dao的方法 1.1 SqlSession使用范围 1.1.1 SqlSessionFactoryBuilder //以流的方式读取总的配置文件 Reader rea ...
- spring与mybatis五种整合方法
1.采用数据映射器(MapperFactoryBean)的方式 不用写mybatis映射文件,采用注解方式提供相应的sql语句和输入参数. (1)Spring配置文件: <!-- 引入jdbc ...
- MyBatis(3)开发dao方法
本次全部学习内容:MyBatisLearning SqlSession SqlSession是一个面向用户(程序员)的接口. SqlSession中提供了很 ...
- 为什么不应该重写service方法?
故事通常是这样开始的: 从前,有一个程序猿,他语重心长地对孙子说:“孩子,要是你以后写servlet,最好不要重写service方法啊” 孙子大为不解,程序猿又说:“听爷爷的,准没错,爷爷的爷爷就 ...
- mybatis学习记录二——mybatis开发dao的方法
4.1 SqlSession使用范围 4.1.1 SqlSessionFactoryBuilder 通过SqlSessionFactoryBuilder创建会话工厂SqlSession ...
- Mybatis学习记录(二)----mybatis开发dao的方法
1 SqlSession使用范围 1.1 SqlSessionFactoryBuilder 通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory 将Sq ...
- Mybatis 开发 dao 的方法
1.分析SqlSession使用范围 1.1.SqlSessionFactoryBuilder 通过 SqlSessionFactoryBuilder 创建会话工厂 SqlSessionFactory ...
- spring与mybatis三种整合方法
spring与mybatis三种整合方法 本文主要介绍Spring与Mybatis三种常用整合方法,需要的整合架包是mybatis-spring.jar,可通过链接 http://code.googl ...
随机推荐
- json套娃其实是这样套的!
- cheat.sh在手,天下我有
前言 作为程序员需要了解的东西有很多,日常编码和写脚本脱离不开各式语言与 Linux 命令.为了记住一些杂乱的或不被经常使用的知识点,我们迫切需要一个"小抄"/备忘录,小抄内容多了 ...
- LaTex中的中文处理方法
相关代码与注释: 显示效果:
- django中的积累
只要继承了model.Model, 就会生成一个新的表,但是,如果在Meta方法中添加abstract=True,就不会产生新的表,而是作为一个基类存放多个表共同拥有的方法和字段等 from djan ...
- SQL注入步骤
1.判断是否存在注入,注入是字符型还是数字型2.猜解SQL查询语句中的字段数3.确定回显的字段数4.获取当前数据库5.获取表中字段名6.下载数据
- LeetCode 037 Sudoku Solver
题目要求:Sudoku Solver Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells ...
- Docker 跨平台在 netCore 中的从入门到部署
前言 从题目我们可以看的出,今天是五部曲的第三部,你可能会好奇,为啥没有见到前两部呢?这里我简单说下: 1.跨平台第一部曲:MySql 如果你看我的所有开源项目,应该能发现我已经全部迁移到了Mysql ...
- 20200311_最新爬取mzitu
废话不多, 直接上代码, python3.6: import requests from bs4 import BeautifulSoup import os import time; import ...
- 20191017_datatable.select() 数据源中没有dataRow
filterStr =" 记录时间 >= '2019/10/17 00:00:00' and 记录时间 <='2019/10/20 23:59:59' " 代码: dg ...
- linux搭建harbor与使用
条件:安装docker&docker-compose 如未安装,请看:linux离线安装docker + docker-compose harbor 1.下载 下载地址:https://git ...