Java多条件筛选应使用MyBatis-Plus的QueryWrapper实现动态查询,自动忽略空值,避免SQL注入;需封装ConditionBuilder解耦逻辑,建立联合索引优化性能。
Java中实现多条件筛选,核心在于构建灵活、可扩展的动态查询逻辑,避免硬编码SQL或大量if-else拼接。关键不是写死条件,而是让查询条件“可插拔”——用户选了哪些字段、填了哪些值,系统就自动加入对应WHERE子句。
MyBatis-Plus的QueryWrapper天然支持链式调用和空值跳过,是实现多条件筛选最常用且简洁的方式。它会自动忽略值为null、空字符串或集合为空的条件。
QueryWrapper
wrapper.like(StringUtils.isNotBlank(username), "username", username)
.eq(status != null, "status", status)
.between(startTime != null && endTime != null, "create_time", startTime, endTime);
当筛选字段较多(如10+个)、规则较复杂(模糊+精确+范围+IN多选)时,建议将条件解析提取为独立组件,比如ConditionBuilder类。它接收DTO对象,按约定规则转换为QueryWrapper或Criteria对象。
绝对不要用wrapper.apply("age > " + age)这类方式拼接用户输入——存在SQL注入风险。所有用户输入必须走参数化占位符(?)。
多条件组合容易导致全表扫描。即使功能跑通,也要关注实际执行效率。