All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.kfcfans.oms.worker.persistence.SimpleTaskQuery Maven / Gradle / Ivy

There is a newer version: 2.0.0
Show newest version
package com.github.kfcfans.oms.worker.persistence;

import lombok.Data;
import org.springframework.util.StringUtils;

/**
 * 简单查询直接类,只支持 select * from task_info where xxx = xxx and xxx = xxx 的查询
 *
 * @author tjq
 * @since 2020/3/17
 */
@Data
public class SimpleTaskQuery {

    private static final String LINK = " and ";

    private String taskId;
    private Long subInstanceId;
    private Long instanceId;
    private String taskName;
    private String address;
    private Integer status;

    // 自定义的查询条件(where 后面的语句),如 crated_time > 10086 and status = 3
    private String queryCondition;
    // 自定义的查询条件,如 GROUP BY status
    private String otherCondition;

    // 查询内容,默认为 *
    private String queryContent = " * ";

    private Integer limit;

    public String getQueryCondition() {
        StringBuilder sb = new StringBuilder();
        if (!StringUtils.isEmpty(taskId)) {
            sb.append("task_id = '").append(taskId).append("'").append(LINK);
        }
        if (subInstanceId != null) {
            sb.append("sub_instance_id = ").append(subInstanceId).append(LINK);
        }
        if (instanceId != null) {
            sb.append("instance_id = ").append(instanceId).append(LINK);
        }
        if (!StringUtils.isEmpty(address)) {
            sb.append("address = '").append(address).append("'").append(LINK);
        }
        if (!StringUtils.isEmpty(taskName)) {
            sb.append("task_name = '").append(taskName).append("'").append(LINK);
        }
        if (status != null) {
            sb.append("status = ").append(status).append(LINK);
        }

        if (!StringUtils.isEmpty(queryCondition)) {
            sb.append(queryCondition).append(LINK);
        }

        String substring = sb.substring(0, sb.length() - LINK.length());

        if (!StringUtils.isEmpty(otherCondition)) {
            substring += otherCondition;
        }

        if (limit != null) {
            substring = substring + " limit " + limit;
        }
        return substring;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy