MyBatis Plus 在复杂查询条件Where中加括号,多个查询条件在括号内

一、MyBatis Plus 在复杂查询条件Where中加括号,多个查询条件在括号内

使用and()方法

官方给出示例:

and(i -> i.eq("name", "李白").ne("status", "活着"))

---> sql输出结果:and (name = '李白' and status <> '活着')

二、QueryWrapper无条件时

1  QueryWrapper<Demo> queryWrapper = new QueryWrapper<>();
2         queryWrapper.and(query -> query.like(StringUtils.isNotBlank(demo.getName()), "demo.name", demo.getName()).or().
3  like(StringUtils.isNotBlank(demo.getFrontId()), "demo.frontId", demo.getFrontId()));
4  
5  ------> sql输出结果:
6  select id, name, frontId from demo where ( turbine.name LIKE '%测%'  OR turbine.frontId LIKE '%测%') 

三、QueryWrapper有条件时

 

1  QueryWrapper<Demo> queryWrapper = new QueryWrapper<>();
2  queryWrapper.eq("id",demo.getId);
3 queryWrapper.and(query -> query.like(StringUtils.isNotBlank(demo.getName()), "demo.name", demo.getName()).or().
4 like(StringUtils.isNotBlank(demo.getFrontId()), "demo.frontId", demo.getFrontId()));
5  
6  ------> sql输出结果:
7  select id, name, frontId from demo where id = 1 and ( turbine.name LIKE '%测%'  OR turbine.frontId LIKE '%测%') 

四、理解MyBatis Plusand()方法

  • 如果QueryWrapper对象没有查询条件,则只会在where语句中添加 ()
  • 如果QueryWrapper对象中有查询条件了,会在where语句中自动添加 and(查询条件)

五:基于queryWrapper实现分页查询

LambdaQueryWrapper<> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.like(StringUtils.isNoneBlank(rectificationActivityInfo.getActivityName()),RectificationActivityInfo::getActivityName,rectificationActivityInfo.getActivityName());
        queryWrapper.eq(StringUtils.isNoneBlank(rectificationActivityInfo.getStatus()),RectificationActivityInfo::getStatus,rectificationActivityInfo.getStatus());
        IPage<RectificationActivityInfo> page1 = this.page(page, queryWrapper);

 六:lambdaQueryWrapper 基于复杂sql的使用;

1  LambdaQueryWrapper<CarInfo> wrapper = new LambdaQueryWrapper<>();
2         wrapper.eq(CarInfo::getUsername,username);
3         wrapper.and(StringUtils.isBlank(VIN),x->x.eq(CarInfo::getVinNum,VIN).or(StringUtils.isBlank(autoSN),query->query.eq(CarInfo::getMachineNum,VIN)));
4         

 七、手写sql

八、mybaties的select and  or查询

复制代码
 queryWrapper.eq("id", Id);
 queryWrapper.and(wrapper ->
                wrapper.eq("expire_time", 0)
                        .or()
                        .gt("expire_time",System.currentTimeMillis() / 1000)
);
 queryWrapper.select("sum(point) as point, sum(valid_points) as valid_points");

StudentDo studentDo = studentMapper.selectOne(queryWrapper);
===================================输出sql
SELECT sum(point) as point, sum(valid_points) as valid_points from student where id = "111" and (expire_time = 0 or expire_time > "2555")
复制代码

 九.lambdaQueryWrapper基于select字段的查询

LambdaQueryWrapper<MdmCountry> wrapper1 = new LambdaQueryWrapper<>();
                                wrapper1.eq(MdmCountry::getCountryCode,countrycode);
                                wrapper1.select(MdmCountry::getCountryCode,MdmCountry::getCountryName,MdmCountry::getAreaId,MdmCountry::getAreaName,MdmCountry::getNationalCompanyId,MdmCountry::getNationalCompanyName);
                                List<MdmCountry> mdmCountries = mdmCountryMapper.selectList(wrapper1);

 

posted @   Jerry&Ming  阅读(2653)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示