使用mybatis-plus,实现将排序时,字段值为NULL的数据排在最后

背景

业务需要根据一个时间字段进行排序,该字段非必填,使用 mybatis 默认排序规则,会将值为 NULL 的数据排在最前面,希望升序时,值为 NULL 的数据排在最后。

实现

错误实现

由于项目使用 mybatis-plus 进行查询,最开始想到的就是使用.last()方法,但试验后发现不行,在最后拼接语句,依旧会造成 NULL 值在最后

解决方案

查看 mybatis-plus 源码,发现其底层的实现思路是

发现 wrapper 中可以直接获取这个 expression

直接模仿该方法即可,将 NULL 值排序到最后的操作,放在排序规则第一个

实现

java 复制代码
    /**
     * 排序时,将字段column为null的数据排到最后面
     * <pre>
     *     ORDER BY
     *             age DESC,
     *             CASE WHEN age IS NULL THEN 1 ELSE 0 END ASC
     *
     * </pre>
     *
     * @since 3.8.0.RC5
     */
    private static final String ORDER_POST_NULL = "CASE WHEN {} IS NULL THEN 1 ELSE 0 END";

    /**
     * 排序时,将为字段column中,值为null的数据排在最后
     *
     * @param column 排序字段
     * @return CASE 语句:CASE WHEN age IS NULL THEN 1 ELSE 0 END
     * @since 3.8.0.RC5
     */
    public static <T> String getOrderNullPostSql(SFunction<T, ?> column) {
        return StrUtil.format(ORDER_POST_NULL, NtsWrappers.getColumnName(column));
    }

    /**
     * 将字段column中,值为null的数据排在最后
     *
     * @param queryWrapper 查询条件构造器
     * @param column       排序字段
     * @param <T>          数据库实体类泛型
     * @since 3.8.0.RC5
     */
    public static <T> void orderNullPost(LambdaQueryWrapper<T> queryWrapper, SFunction<T, ?> column) {
        queryWrapper.getExpression().add(ORDER_BY, () -> getOrderNullPostSql(column), ASC);
    }

使用时,在调用 mybatis-plus 的排序方法前先调用 orderBullPost 方法

相关推荐
桦说编程2 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅4 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者5 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺5 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart6 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP7 小时前
MyBatis-mybatis入门与增删改查
java
孟陬10 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌11 小时前
一站式了解四种限流算法
java·后端·go
华仔啊11 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java