mp wrapper小技巧

简介: mp wrapper小技巧

别让你的舌头超越你的思想。——第欧根尼

对于mpwrapper,直接使用nested+or是可以正确执行的

例如:

Db.list(Wrappers.lambdaQuery(UserInfo.class).or().eq(UserInfo::getName, "Jon"));

生成

2023-04-13 22:39:54.858 DEBUG 20668 --- [           main] o.d.s.s.p.m.m.UserInfoMapper.selectList  : ==>  Preparing: SELECT id,name,age,email,version,gmt_deleted FROM user_info WHERE gmt_deleted='2001-01-01 00:00:00' AND (name = ?)
2023-04-13 22:39:54.858 DEBUG 20668 --- [           main] o.d.s.s.p.m.m.UserInfoMapper.selectList  : ==> Parameters: Jon(String)

这样的技巧可以让我们在循环里拼接or时,无须考虑是否为第一个元素

例如stream-query中的封装:

/**
 * or 查询
 *
 * @param wrapper 条件构造器
 * @param dataList 数据
 * @param biConsumer 逻辑处理
 * @param <W> 条件构造器
 * @param <T> 实体类型
 * @param <R> 数据类型
 * @return 条件构造器
 */
public static <W extends AbstractWrapper<T, ?, W>, T, R> W multiOr(
    W wrapper, Collection<R> dataList, BiConsumer<W, R> biConsumer) {
  if (Lists.isEmpty(dataList)) {
    return Database.notActive(wrapper);
  }
  return wrapper.nested(w -> dataList.forEach(data -> biConsumer.accept(w.or(), data)));
}


使用起来:

val dataList =
    Lists.of(
        new UserInfo() {
          {
            setName("Jon");
          }
        },
        new UserInfo() {
          {
            setEmail("test2@baomidou.com");
          }
        },
        new UserInfo() {
          {
            setName("Tom");
          }
        });
val wrapper =
    WrapperHelper.multiOr(
        Wrappers.lambdaQuery(UserInfo.class),
        dataList,
        (w, data) -> {
          w.eq(Objects.nonNull(data.getEmail()), UserInfo::getEmail, data.getEmail())
              .eq(StringUtils.isNotBlank(data.getName()), UserInfo::getName, data.getName());
        });
// ==>  Preparing: SELECT id,name,age,email,version,gmt_deleted FROM user_info WHERE
// gmt_deleted='2001-01-01 00:00:00' AND ((name = ? OR email = ? OR name = ?))
// ==> Parameters: Jon(String), test2@baomidou.com(String), Tom(String)
List<UserInfo> userInfos = Database.list(wrapper);
Assertions.assertEquals("Jon", userInfos.get(0).getName());
Assertions.assertEquals("test2@baomidou.com", userInfos.get(1).getEmail());
Assertions.assertEquals("Tom", userInfos.get(2).getName());
相关文章
|
3月前
|
Python
音乐播放 pygame mp3play 和获取音乐信息的 库from mutagen.mp3 import MP3
音乐播放 pygame mp3play 和获取音乐信息的 库from mutagen.mp3 import MP3
|
JavaScript
08HUI - 媒体列表(hui-media-list-img)
08HUI - 媒体列表(hui-media-list-img)
32 0
|
druid 前端开发 Java
数据持久化技术——MP(一)
数据持久化技术——MP(一)
312 0
数据持久化技术——MP(一)
|
SQL XML 前端开发
数据持久化技术——MP(二)
数据持久化技术——MP(二)
237 0
数据持久化技术——MP(二)
数据持久化技术——MP(三)
数据持久化技术——MP(三)
136 0
|
vr&ar
AR Video Demo
AR Video Demo
152 0
AR Video Demo
|
Android开发
5-AVI--Fragment简单封装
零、前言 [1].每次写Fragment要加载布局,为布局设置内容,挺麻烦的,搞个基类简单封装一下吧 [2].一般封装基类使用模板方法设计模式,基类中做一些常用的不变东西,需要拐点弯的逻辑就弄个抽象方法延迟到子类 [3].
1034 0
|
前端开发 Java 数据库连接
MP实战系列(四)之DAO讲解
说到DAO不得不提一个开发名词"三层架构",所谓的三层架构是什么呢?简单的可以概括为数据访问层,业务逻辑层,界面层(又称表现层). 这也是我们Java开发常用的手段,经常有人将三层架构和mvc模式混淆,在我看来,三层架构就是三层架构,mvc只是三层架构中的表现层中的架构,相当于在一个比较大的层面,往...
2043 0