按照状态实现自定义排序的方法

方法一:使用 MyBatis-Plus 的 QueryWrapper 自定义排序

在查询时动态构建排序规则,通过 CASE WHEN 语句实现优先级排序:

java 复制代码
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.springframework.stereotype.Service;

@Service
public class ProjectConfigService {

    public List<ProjectConfigEntity> listProjectsByStatusPriority() {
        // 自定义排序:进行中(1) > 已完成(2) > 待启动(0)
        QueryWrapper<ProjectConfigEntity> queryWrapper = new QueryWrapper<>();
        queryWrapper.orderByAsc("CASE " +
                "WHEN project_status = 1 THEN 1 " +  // 进行中排第一
                "WHEN project_status = 2 THEN 2 " +  // 已完成排第二
                "ELSE 3 END");                      // 待启动排第三

        return projectConfigMapper.selectList(queryWrapper);
    }
}

方法二:在实体类中使用 @TableField 注解添加默认排序

如果你希望所有查询都自动应用此排序规则,可以在实体类中添加默认排序注解:

java 复制代码
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.IdType;
import lombok.Data;

@Data
@TableName("dste_project_config_new")
public class ProjectConfigEntity implements Serializable {

    private static final long serialVersionUID = 1L;
    
    // 其他字段保持不变...

    /**
     * 项目状态(0:待启动,1:进行中,2:已完成)
     */
    @TableField(value = "project_status", condition = "%s = CASE WHEN project_status = 1 THEN 1 " +
                                                     "WHEN project_status = 2 THEN 2 " +
                                                     "ELSE 3 END")
    private Integer projectStatus;
}

方法三:使用自定义 SQL 查询

如果你需要更复杂的排序逻辑,可以在 Mapper 接口中定义自定义 SQL:

java 复制代码
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Select;
import java.util.List;

public interface ProjectConfigMapper extends BaseMapper<ProjectConfigEntity> {

    @Select("SELECT * FROM dste_project_config_new " +
            "ORDER BY CASE " +
            "WHEN project_status = 1 THEN 1 " +
            "WHEN project_status = 2 THEN 2 " +
            "ELSE 3 END")
    List<ProjectConfigEntity> selectProjectsByStatusPriority();
}

方法四:使用 MyBatis-Plus 的 LambdaQueryWrapper自定义排序

java 复制代码
    public List<ProjectConfigEntity> listProjectsByStatusPriority() {
        // 使用LambdaQueryWrapper实现类型安全的自定义排序
        LambdaQueryWrapper<ProjectConfigEntity> wrapper = new LambdaQueryWrapper<>();
        wrapper.orderByAsc(true, 
            "CASE " +
            "WHEN project_status = 1 THEN 1 " +  // 进行中排第一
            "WHEN project_status = 2 THEN 2 " +  // 已完成排第二
            "ELSE 3 END");

        return projectConfigMapper.selectList(wrapper);
    }

方法五:避免硬编码表字段名,可以结合实体类的属性名和 SQL 片段

java 复制代码
	LambdaQueryWrapper<ProjectConfigEntity> wrapper = new LambdaQueryWrapper<>();
	String statusSortSql = String.format(
	    "CASE " +
	    "WHEN %s = 1 THEN 1 " +
	    "WHEN %s = 2 THEN 2 " +
	    "ELSE 3 END",
	    StringUtils.camelToUnderline(ProjectConfigEntity::getProjectStatus), // 驼峰转下划线
	    StringUtils.camelToUnderline(ProjectConfigEntity::getProjectStatus)
	);
	
	wrapper.orderByAsc(true, statusSortSql);

排序原理说明

以上五种方法均基于 SQL 的 CASE WHEN 语句实现自定义排序:

  1. 进行中(状态值=1):优先级最高,排序值为 1
  2. 已完成(状态值=2):优先级次之,排序值为 2
  3. 待启动(状态值=0):优先级最低,排序值为 3
相关推荐
今天背单词了吗9805 分钟前
算法学习笔记:27.堆排序(生日限定版)——从原理到实战,涵盖 LeetCode 与考研 408 例题
java·程序人生·算法·堆排序·节日
小凡敲代码8 分钟前
2025年Java后端秋招面试的高频八股文+场景题
java·面试·程序员·java面试·java面试题·互联网大厂·java场景题
今天背单词了吗98010 分钟前
算法学习笔记:26.二叉搜索树(生日限定版)——从原理到实战,涵盖 LeetCode 与考研 408 例题
java·学习·算法··二叉搜索树
DKPT11 分钟前
Java行为型模式(状态模式)实现方式与测试方法
java·笔记·学习·设计模式·状态模式
一个快乐的小测试12 分钟前
JUnit-自动化测试框架
java·junit·单元测试·自动化
ai小鬼头20 分钟前
如何高效管理程序员与AIStarter开发:避免Bug的经验分享
java·架构·github
SXU_TSUKI_JAVA35 分钟前
菜单权限管理
java
William Dawson36 分钟前
【前端如何利用 localStorage 存储 Token 及跨域问题解决方案】
java·chrome
阿华的代码王国36 分钟前
【Android】按钮的使用
android·xml·java
麦兜*3 小时前
SpringBoot 3.x集成阿里云OSS:文件上传 断点续传 权限控制
java·spring boot·后端·spring·spring cloud·阿里云·maven