FluentMybatis Where语法(一) | FluentMybatis实践(1)

简介: FluentMybatis Where语法(一) | FluentMybatis实践

前言

这几天在出差,没时间更新FluentMybatis相关的内容。接着上一篇:FluentMybatis 聚合查询、apply方法 | FluentMybatis实践_阿良的博客-CSDN博客


继续测试fm的其他语法,where语法的使用。


GitHub仓库:github项目地址



数据准备

随便弄几条数据。


image.png


Where基本条件语法

先看看where的基本语法,例如:> , = , < , >= , <= , <> , between , not between , in , not in , is null , is not null等等。随便选几个测试一下。


接口代码


package com.hy.fmp.service;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import java.util.List;
/** @Author huyi @Date 2021/11/8 19:48 @Description: where语法 */
public interface IWhereService {
  /**
   * 测试ge
   *
   * @return list
   */
  List<TestFluentMybatisEntity> query1();
  /**
   * 测试in
   *
   * @return list
   */
  List<TestFluentMybatisEntity> query2();
  /**
   * 测试between
   *
   * @return list
   */
  List<TestFluentMybatisEntity> query3();
  /**
   * 测试is null
   *
   * @return list
   */
  List<TestFluentMybatisEntity> query4();
}


实现代码

package com.hy.fmp.service.Impl;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import com.hy.fmp.fluent.mapper.TestFluentMybatisMapper;
import com.hy.fmp.fluent.wrapper.TestFluentMybatisQuery;
import com.hy.fmp.service.IWhereService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/** @Author huyi @Date 2021/11/8 20:10 @Description: where语法接口实现类 */
@Slf4j
@Service
public class IWhereServiceImpl implements IWhereService {
  @Autowired private TestFluentMybatisMapper testFluentMybatisMapper;
  @Override
  public List<TestFluentMybatisEntity> query1() {
    return testFluentMybatisMapper.listEntity(
        new TestFluentMybatisQuery().where.age().ge(30).end());
  }
  @Override
  public List<TestFluentMybatisEntity> query2() {
    return testFluentMybatisMapper.listEntity(
        new TestFluentMybatisQuery().where.age().in(new int[] {30, 78, 64}).end());
  }
  @Override
  public List<TestFluentMybatisEntity> query3() {
    return testFluentMybatisMapper.listEntity(
        new TestFluentMybatisQuery().where.age().between(10, 50).end());
  }
  @Override
  public List<TestFluentMybatisEntity> query4() {
    return testFluentMybatisMapper.listEntity(
        new TestFluentMybatisQuery().where.age().isNull().end());
  }
}

控制层代码

package com.hy.fmp.ctrl;
import com.hy.fmp.dto.Result;
import com.hy.fmp.enm.ErrorCode;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import com.hy.fmp.service.IWhereService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
/** @Author huyi @Date 2021/11/8 20:15 @Description: where语法控制层 */
@Slf4j
@RestController
@RequestMapping("/where")
@Api(tags = "where语法")
public class WhereController {
  @Autowired private IWhereService whereService;
  @ApiOperation(value = "where-ge语法", notes = "where-ge语法")
  @RequestMapping(value = "/ge", method = RequestMethod.GET)
  @ResponseBody
  public Result<List<TestFluentMybatisEntity>> query1() {
    try {
      return Result.ok(whereService.query1());
    } catch (Exception exception) {
      return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);
    }
  }
  @ApiOperation(value = "where-in语法", notes = "where-in语法")
  @RequestMapping(value = "/in", method = RequestMethod.GET)
  @ResponseBody
  public Result<List<TestFluentMybatisEntity>> query2() {
    try {
      return Result.ok(whereService.query2());
    } catch (Exception exception) {
      return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);
    }
  }
  @ApiOperation(value = "where-between语法", notes = "where-between语法")
  @RequestMapping(value = "/between", method = RequestMethod.GET)
  @ResponseBody
  public Result<List<TestFluentMybatisEntity>> query3() {
    try {
      return Result.ok(whereService.query3());
    } catch (Exception exception) {
      return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);
    }
  }
  @ApiOperation(value = "where-isNull语法", notes = "where-isNull语法")
  @RequestMapping(value = "/isNull", method = RequestMethod.GET)
  @ResponseBody
  public Result<List<TestFluentMybatisEntity>> query4() {
    try {
      return Result.ok(whereService.query4());
    } catch (Exception exception) {
      return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);
    }
  }
}

验证一下


image.png



image.png

没什么问题。

目录
打赏
0
0
0
0
7
分享
相关文章
JAVAEE框架技术之7-myBatis ORM框架入门基础CRUD
JAVAEE框架技术之7-myBatis ORM框架入门基础CRUD
178 0
JAVAEE框架技术之7-myBatis ORM框架入门基础CRUD
MyBatis-Plus高级用法:最优化持久层开发
MyBatis-Plus 通过简化常见的持久层开发任务,提高了开发效率和代码的可维护性。通过合理使用条件构造器、分页插件、逻辑删除和代码生成器等高级功能,可以进一步优化持久层开发,提升系统性能和稳定性。掌握这些高级用法和最佳实践,有助于开发者构建高效、稳定和可扩展的企业级应用。
81 13
如何利用Mybatis-Plus自动生成代码(超详细注解)
如何利用Mybatis-Plus自动生成代码(超详细注解)
2534 1
|
8月前
|
JAVAEE框架技术之8-myBatis ORM框架技术参数和动态SQL语句
JAVAEE框架技术之8-myBatis ORM框架技术参数和动态SQL语句
101 0
JAVAEE框架技术之8-myBatis ORM框架技术参数和动态SQL语句
JAVAEE框架技术之9-myBatis高级查询技术文档
JAVAEE框架技术之9-myBatis高级查询技术文档
137 0
JAVAEE框架技术之9-myBatis高级查询技术文档
干翻Mybatis源码系列之第十篇:Mybatis拦截器基本开发、基本使用和基本细节分析
干翻Mybatis源码系列之第十篇:Mybatis拦截器基本开发、基本使用和基本细节分析
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等