mybatis自定义复杂条件拼接

  1. 定义条件对象
java 复制代码
/**
 * @description:
 * @author: yilv
 * @create: 2024-08-26 17:35
 **/
@Data
public class ComplexQueryDto {
    /**
     * 查询参数
     */
    private List<QueryDto> params=new ArrayList<>();

    public ComplexQueryDto addParam(QueryDto queryDto){
        this.params.add(queryDto);
        return this;
    }
}
  1. 定义查询对象
java 复制代码
/**
 * @description: 通用查询对象
 * @author: yilv
 * @create: 2024-08-26 17:42
 **/
@Data
@Accessors(chain =true)
public class QueryDto {
    /**
     * 字段名
     */
    private String filedName;

    /**
     * 比较运算符
     */
    private String opt;

    /**
     * 单值
     */
    private String filedValue;

    /**
     * 多值集合
     */
    private String[] filedValues;
    /**
     * 关系符
     */
    private String rel;
}
  1. 查询条件枚举
java 复制代码
/**
 * 操作符
 */
@Getter
public enum QueryOpt {
    //非空
    NOT_NULL("IS NOT NULL"),
    //包含")
    IN("IN"),
    //不包含")
    NOT_IN("NOT IN"),
    //存在")
    LIKE("LIKE"),
    //不存在")
    NOT_LIKE("NOT LIKE"),
    //等于")
    EQ("="),
    //不等于")
    NE("!="),
    //大于")
    GT(">"),
    //大于等于")
    GE(">="),
    //小于")
    LT("<"),
    //小于等于")
    LE("<="),
    //范围")
    BETWEEN("BETWEEN");
    private final String seg;

    public String getSeg() {
        return seg;
    }

    QueryOpt(String seg) {
        this.seg = seg;
    }
}
  1. 查询关系枚举
java 复制代码
/**
 * 关联运算符
 */
@Getter
public enum QueryRel {
    //与")
    AND("AND"),
    //或")
    OR("OR"),
    //非")
    NOT("NOT");
    private final String seg;

    public String getSeg() {
        return seg;
    }

    QueryRel(String seg) {
        this.seg = seg;
    }
}
  1. 编写条件拼接SQL
xml 复制代码
    <sql id="complexQuery">
        <if test="params != null and params.size() != 0">
            <foreach item="param" index="index" collection="params">
                AND ${param.filedName} ${param.opt}
                <if test="param.opt == 'BETWEEN'">#{param.filedValues[0]} AND #{param.filedValues[0]}</if>
                <if test="param.opt == 'IN'||param.opt == 'NOT IN'">
                    <foreach item="filedValue" index="index" collection="param.filedValues" open="(" separator="," close=")">
                        #{filedValue}
                    </foreach>
                </if>
            </foreach>
        </if>
    </sql>


    <select id="??Query" resultMap="??">
        SELECT
        <include refid="div_Column_List"></include>
        FROM
        <include refid="table"></include>
        <include refid="complexQuery"></include>
    </select>
相关推荐
IvorySQL15 小时前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData16 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
IvorySQL21 小时前
PostgreSQL 技术日报 (3月5日)|规划器控制力升级,内核能力再进阶
数据库·postgresql·开源
数据组小组1 天前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
爱可生开源社区2 天前
MiniMax M2.5 的 SQL 能力令人惊艳!
sql·llm
Nyarlathotep01132 天前
事务隔离级别
sql·mysql
悟空聊架构2 天前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL2 天前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
Nyarlathotep01132 天前
SQL的事务控制
sql·mysql