MybatisPlus高级特性之SimpleQuery工具类
1、是很么?
SimpleQuery可以对selectList查询后的结果使用Stream流进行操作,使其可以返回指定的结果,简洁了api的调用
2、怎么玩?
案例演示
(1) list操作
/**
* list(LambdaQueryWrapper<E> wrapper, SFunction<E, A> sFunction, Consumer<E>... peeks)
* 参数说明:
* param1 : 查询条件
* param2 : SFunction类型的函数式接口;你想要做了操作
*/
@Test
public void testList1() {
List<String> stringList = SimpleQuery.list(Wrappers.<Employee>lambdaQuery()
.gt(Employee::getId, 1), Employee::getName);
System.out.println("stringList = " + stringList);
}
/**
* list(LambdaQueryWrapper<E> wrapper, SFunction<E, A> sFunction, boolean isParallel, Consumer<E>... peeks)
* 参数说明:
* param1 : 查询条件
* param2 : SFunction类型的函数式接口;你想要做了操作
* param3 : 是否并行操作
* param4 : 转换后的后续流操作
*/
@Test
public void testList2() {
List<String> stringList = SimpleQuery.list(Wrappers.<Employee>lambdaQuery()
.gt(Employee::getId, 1), Employee::getName,
e -> Optional.of(e.getName()).map(String::toUpperCase).ifPresent(e::setName));
System.out.println("stringList = " + stringList);
}
(2) map操作
@Test
public void testMap1(){
Map<Integer, Employee> keyedMap = SimpleQuery.keyMap(Wrappers.<Employee>lambdaQuery()
.gt(Employee::getId, 1), Employee::getId);
System.out.println("keyedMap = " + keyedMap);
}
@Test
public void testMap2(){
Map<Integer, Employee> keyed = SimpleQuery.keyMap(Wrappers.<Employee>lambdaQuery()
.gt(Employee::getId, 1), Employee::getId, Employee::getName);
System.out.println("keyed = " + keyed);
(3) group操作
@Test
public void testGroup(){
Map<String, List<Employee>> map = SimpleQuery.group(Wrappers.<Employee>lambdaQuery()
.gt(Employee::getId, 1), Employee::getSex);
System.out.println("map = " + map);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
2022-04-30 微信支付整合