package pwc.taxtech.atms.vat.entity;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class IndexAnalysisDetailResultExample {
    /**
     * This field was generated by MyBatis Generator.
     * This field corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    protected String orderByClause;

    /**
     * This field was generated by MyBatis Generator.
     * This field corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    protected boolean distinct;

    /**
     * This field was generated by MyBatis Generator.
     * This field corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    protected List<Criteria> oredCriteria;

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public IndexAnalysisDetailResultExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public String getOrderByClause() {
        return orderByClause;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public boolean isDistinct() {
        return distinct;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    /**
     * This class was generated by MyBatis Generator.
     * This class corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIDIsNull() {
            addCriterion("ID is null");
            return (Criteria) this;
        }

        public Criteria andIDIsNotNull() {
            addCriterion("ID is not null");
            return (Criteria) this;
        }

        public Criteria andIDEqualTo(String value) {
            addCriterion("ID =", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDNotEqualTo(String value) {
            addCriterion("ID <>", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDGreaterThan(String value) {
            addCriterion("ID >", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDGreaterThanOrEqualTo(String value) {
            addCriterion("ID >=", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDLessThan(String value) {
            addCriterion("ID <", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDLessThanOrEqualTo(String value) {
            addCriterion("ID <=", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDLike(String value) {
            addCriterion("ID like", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDNotLike(String value) {
            addCriterion("ID not like", value, "ID");
            return (Criteria) this;
        }

        public Criteria andIDIn(List<String> values) {
            addCriterion("ID in", values, "ID");
            return (Criteria) this;
        }

        public Criteria andIDNotIn(List<String> values) {
            addCriterion("ID not in", values, "ID");
            return (Criteria) this;
        }

        public Criteria andIDBetween(String value1, String value2) {
            addCriterion("ID between", value1, value2, "ID");
            return (Criteria) this;
        }

        public Criteria andIDNotBetween(String value1, String value2) {
            addCriterion("ID not between", value1, value2, "ID");
            return (Criteria) this;
        }

        public Criteria andResultIDIsNull() {
            addCriterion("ResultID is null");
            return (Criteria) this;
        }

        public Criteria andResultIDIsNotNull() {
            addCriterion("ResultID is not null");
            return (Criteria) this;
        }

        public Criteria andResultIDEqualTo(String value) {
            addCriterion("ResultID =", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDNotEqualTo(String value) {
            addCriterion("ResultID <>", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDGreaterThan(String value) {
            addCriterion("ResultID >", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDGreaterThanOrEqualTo(String value) {
            addCriterion("ResultID >=", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDLessThan(String value) {
            addCriterion("ResultID <", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDLessThanOrEqualTo(String value) {
            addCriterion("ResultID <=", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDLike(String value) {
            addCriterion("ResultID like", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDNotLike(String value) {
            addCriterion("ResultID not like", value, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDIn(List<String> values) {
            addCriterion("ResultID in", values, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDNotIn(List<String> values) {
            addCriterion("ResultID not in", values, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDBetween(String value1, String value2) {
            addCriterion("ResultID between", value1, value2, "resultID");
            return (Criteria) this;
        }

        public Criteria andResultIDNotBetween(String value1, String value2) {
            addCriterion("ResultID not between", value1, value2, "resultID");
            return (Criteria) this;
        }

        public Criteria andYearIsNull() {
            addCriterion("`Year` is null");
            return (Criteria) this;
        }

        public Criteria andYearIsNotNull() {
            addCriterion("`Year` is not null");
            return (Criteria) this;
        }

        public Criteria andYearEqualTo(Integer value) {
            addCriterion("`Year` =", value, "year");
            return (Criteria) this;
        }

        public Criteria andYearNotEqualTo(Integer value) {
            addCriterion("`Year` <>", value, "year");
            return (Criteria) this;
        }

        public Criteria andYearGreaterThan(Integer value) {
            addCriterion("`Year` >", value, "year");
            return (Criteria) this;
        }

        public Criteria andYearGreaterThanOrEqualTo(Integer value) {
            addCriterion("`Year` >=", value, "year");
            return (Criteria) this;
        }

        public Criteria andYearLessThan(Integer value) {
            addCriterion("`Year` <", value, "year");
            return (Criteria) this;
        }

        public Criteria andYearLessThanOrEqualTo(Integer value) {
            addCriterion("`Year` <=", value, "year");
            return (Criteria) this;
        }

        public Criteria andYearIn(List<Integer> values) {
            addCriterion("`Year` in", values, "year");
            return (Criteria) this;
        }

        public Criteria andYearNotIn(List<Integer> values) {
            addCriterion("`Year` not in", values, "year");
            return (Criteria) this;
        }

        public Criteria andYearBetween(Integer value1, Integer value2) {
            addCriterion("`Year` between", value1, value2, "year");
            return (Criteria) this;
        }

        public Criteria andYearNotBetween(Integer value1, Integer value2) {
            addCriterion("`Year` not between", value1, value2, "year");
            return (Criteria) this;
        }

        public Criteria andPeriodIsNull() {
            addCriterion("Period is null");
            return (Criteria) this;
        }

        public Criteria andPeriodIsNotNull() {
            addCriterion("Period is not null");
            return (Criteria) this;
        }

        public Criteria andPeriodEqualTo(Integer value) {
            addCriterion("Period =", value, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodNotEqualTo(Integer value) {
            addCriterion("Period <>", value, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodGreaterThan(Integer value) {
            addCriterion("Period >", value, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodGreaterThanOrEqualTo(Integer value) {
            addCriterion("Period >=", value, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodLessThan(Integer value) {
            addCriterion("Period <", value, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodLessThanOrEqualTo(Integer value) {
            addCriterion("Period <=", value, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodIn(List<Integer> values) {
            addCriterion("Period in", values, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodNotIn(List<Integer> values) {
            addCriterion("Period not in", values, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodBetween(Integer value1, Integer value2) {
            addCriterion("Period between", value1, value2, "period");
            return (Criteria) this;
        }

        public Criteria andPeriodNotBetween(Integer value1, Integer value2) {
            addCriterion("Period not between", value1, value2, "period");
            return (Criteria) this;
        }

        public Criteria andIndexNameIsNull() {
            addCriterion("IndexName is null");
            return (Criteria) this;
        }

        public Criteria andIndexNameIsNotNull() {
            addCriterion("IndexName is not null");
            return (Criteria) this;
        }

        public Criteria andIndexNameEqualTo(String value) {
            addCriterion("IndexName =", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameNotEqualTo(String value) {
            addCriterion("IndexName <>", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameGreaterThan(String value) {
            addCriterion("IndexName >", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameGreaterThanOrEqualTo(String value) {
            addCriterion("IndexName >=", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameLessThan(String value) {
            addCriterion("IndexName <", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameLessThanOrEqualTo(String value) {
            addCriterion("IndexName <=", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameLike(String value) {
            addCriterion("IndexName like", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameNotLike(String value) {
            addCriterion("IndexName not like", value, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameIn(List<String> values) {
            addCriterion("IndexName in", values, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameNotIn(List<String> values) {
            addCriterion("IndexName not in", values, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameBetween(String value1, String value2) {
            addCriterion("IndexName between", value1, value2, "indexName");
            return (Criteria) this;
        }

        public Criteria andIndexNameNotBetween(String value1, String value2) {
            addCriterion("IndexName not between", value1, value2, "indexName");
            return (Criteria) this;
        }

        public Criteria andSequenceIsNull() {
            addCriterion("`Sequence` is null");
            return (Criteria) this;
        }

        public Criteria andSequenceIsNotNull() {
            addCriterion("`Sequence` is not null");
            return (Criteria) this;
        }

        public Criteria andSequenceEqualTo(Integer value) {
            addCriterion("`Sequence` =", value, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceNotEqualTo(Integer value) {
            addCriterion("`Sequence` <>", value, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceGreaterThan(Integer value) {
            addCriterion("`Sequence` >", value, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceGreaterThanOrEqualTo(Integer value) {
            addCriterion("`Sequence` >=", value, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceLessThan(Integer value) {
            addCriterion("`Sequence` <", value, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceLessThanOrEqualTo(Integer value) {
            addCriterion("`Sequence` <=", value, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceIn(List<Integer> values) {
            addCriterion("`Sequence` in", values, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceNotIn(List<Integer> values) {
            addCriterion("`Sequence` not in", values, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceBetween(Integer value1, Integer value2) {
            addCriterion("`Sequence` between", value1, value2, "sequence");
            return (Criteria) this;
        }

        public Criteria andSequenceNotBetween(Integer value1, Integer value2) {
            addCriterion("`Sequence` not between", value1, value2, "sequence");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeIsNull() {
            addCriterion("DisplayType is null");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeIsNotNull() {
            addCriterion("DisplayType is not null");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeEqualTo(Integer value) {
            addCriterion("DisplayType =", value, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeNotEqualTo(Integer value) {
            addCriterion("DisplayType <>", value, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeGreaterThan(Integer value) {
            addCriterion("DisplayType >", value, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeGreaterThanOrEqualTo(Integer value) {
            addCriterion("DisplayType >=", value, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeLessThan(Integer value) {
            addCriterion("DisplayType <", value, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeLessThanOrEqualTo(Integer value) {
            addCriterion("DisplayType <=", value, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeIn(List<Integer> values) {
            addCriterion("DisplayType in", values, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeNotIn(List<Integer> values) {
            addCriterion("DisplayType not in", values, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeBetween(Integer value1, Integer value2) {
            addCriterion("DisplayType between", value1, value2, "displayType");
            return (Criteria) this;
        }

        public Criteria andDisplayTypeNotBetween(Integer value1, Integer value2) {
            addCriterion("DisplayType not between", value1, value2, "displayType");
            return (Criteria) this;
        }

        public Criteria andIsVisibleIsNull() {
            addCriterion("IsVisible is null");
            return (Criteria) this;
        }

        public Criteria andIsVisibleIsNotNull() {
            addCriterion("IsVisible is not null");
            return (Criteria) this;
        }

        public Criteria andIsVisibleEqualTo(Integer value) {
            addCriterion("IsVisible =", value, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleNotEqualTo(Integer value) {
            addCriterion("IsVisible <>", value, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleGreaterThan(Integer value) {
            addCriterion("IsVisible >", value, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleGreaterThanOrEqualTo(Integer value) {
            addCriterion("IsVisible >=", value, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleLessThan(Integer value) {
            addCriterion("IsVisible <", value, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleLessThanOrEqualTo(Integer value) {
            addCriterion("IsVisible <=", value, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleIn(List<Integer> values) {
            addCriterion("IsVisible in", values, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleNotIn(List<Integer> values) {
            addCriterion("IsVisible not in", values, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleBetween(Integer value1, Integer value2) {
            addCriterion("IsVisible between", value1, value2, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsVisibleNotBetween(Integer value1, Integer value2) {
            addCriterion("IsVisible not between", value1, value2, "isVisible");
            return (Criteria) this;
        }

        public Criteria andIsMainValueIsNull() {
            addCriterion("IsMainValue is null");
            return (Criteria) this;
        }

        public Criteria andIsMainValueIsNotNull() {
            addCriterion("IsMainValue is not null");
            return (Criteria) this;
        }

        public Criteria andIsMainValueEqualTo(Integer value) {
            addCriterion("IsMainValue =", value, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueNotEqualTo(Integer value) {
            addCriterion("IsMainValue <>", value, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueGreaterThan(Integer value) {
            addCriterion("IsMainValue >", value, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueGreaterThanOrEqualTo(Integer value) {
            addCriterion("IsMainValue >=", value, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueLessThan(Integer value) {
            addCriterion("IsMainValue <", value, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueLessThanOrEqualTo(Integer value) {
            addCriterion("IsMainValue <=", value, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueIn(List<Integer> values) {
            addCriterion("IsMainValue in", values, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueNotIn(List<Integer> values) {
            addCriterion("IsMainValue not in", values, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueBetween(Integer value1, Integer value2) {
            addCriterion("IsMainValue between", value1, value2, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsMainValueNotBetween(Integer value1, Integer value2) {
            addCriterion("IsMainValue not between", value1, value2, "isMainValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueIsNull() {
            addCriterion("IsYearValue is null");
            return (Criteria) this;
        }

        public Criteria andIsYearValueIsNotNull() {
            addCriterion("IsYearValue is not null");
            return (Criteria) this;
        }

        public Criteria andIsYearValueEqualTo(Integer value) {
            addCriterion("IsYearValue =", value, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueNotEqualTo(Integer value) {
            addCriterion("IsYearValue <>", value, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueGreaterThan(Integer value) {
            addCriterion("IsYearValue >", value, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueGreaterThanOrEqualTo(Integer value) {
            addCriterion("IsYearValue >=", value, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueLessThan(Integer value) {
            addCriterion("IsYearValue <", value, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueLessThanOrEqualTo(Integer value) {
            addCriterion("IsYearValue <=", value, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueIn(List<Integer> values) {
            addCriterion("IsYearValue in", values, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueNotIn(List<Integer> values) {
            addCriterion("IsYearValue not in", values, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueBetween(Integer value1, Integer value2) {
            addCriterion("IsYearValue between", value1, value2, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsYearValueNotBetween(Integer value1, Integer value2) {
            addCriterion("IsYearValue not between", value1, value2, "isYearValue");
            return (Criteria) this;
        }

        public Criteria andIsMonExpIsNull() {
            addCriterion("IsMonExp is null");
            return (Criteria) this;
        }

        public Criteria andIsMonExpIsNotNull() {
            addCriterion("IsMonExp is not null");
            return (Criteria) this;
        }

        public Criteria andIsMonExpEqualTo(Integer value) {
            addCriterion("IsMonExp =", value, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpNotEqualTo(Integer value) {
            addCriterion("IsMonExp <>", value, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpGreaterThan(Integer value) {
            addCriterion("IsMonExp >", value, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpGreaterThanOrEqualTo(Integer value) {
            addCriterion("IsMonExp >=", value, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpLessThan(Integer value) {
            addCriterion("IsMonExp <", value, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpLessThanOrEqualTo(Integer value) {
            addCriterion("IsMonExp <=", value, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpIn(List<Integer> values) {
            addCriterion("IsMonExp in", values, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpNotIn(List<Integer> values) {
            addCriterion("IsMonExp not in", values, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpBetween(Integer value1, Integer value2) {
            addCriterion("IsMonExp between", value1, value2, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsMonExpNotBetween(Integer value1, Integer value2) {
            addCriterion("IsMonExp not between", value1, value2, "isMonExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpIsNull() {
            addCriterion("IsYearExp is null");
            return (Criteria) this;
        }

        public Criteria andIsYearExpIsNotNull() {
            addCriterion("IsYearExp is not null");
            return (Criteria) this;
        }

        public Criteria andIsYearExpEqualTo(Integer value) {
            addCriterion("IsYearExp =", value, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpNotEqualTo(Integer value) {
            addCriterion("IsYearExp <>", value, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpGreaterThan(Integer value) {
            addCriterion("IsYearExp >", value, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpGreaterThanOrEqualTo(Integer value) {
            addCriterion("IsYearExp >=", value, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpLessThan(Integer value) {
            addCriterion("IsYearExp <", value, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpLessThanOrEqualTo(Integer value) {
            addCriterion("IsYearExp <=", value, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpIn(List<Integer> values) {
            addCriterion("IsYearExp in", values, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpNotIn(List<Integer> values) {
            addCriterion("IsYearExp not in", values, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpBetween(Integer value1, Integer value2) {
            addCriterion("IsYearExp between", value1, value2, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIsYearExpNotBetween(Integer value1, Integer value2) {
            addCriterion("IsYearExp not between", value1, value2, "isYearExp");
            return (Criteria) this;
        }

        public Criteria andIndexResultIsNull() {
            addCriterion("IndexResult is null");
            return (Criteria) this;
        }

        public Criteria andIndexResultIsNotNull() {
            addCriterion("IndexResult is not null");
            return (Criteria) this;
        }

        public Criteria andIndexResultEqualTo(String value) {
            addCriterion("IndexResult =", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultNotEqualTo(String value) {
            addCriterion("IndexResult <>", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultGreaterThan(String value) {
            addCriterion("IndexResult >", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultGreaterThanOrEqualTo(String value) {
            addCriterion("IndexResult >=", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultLessThan(String value) {
            addCriterion("IndexResult <", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultLessThanOrEqualTo(String value) {
            addCriterion("IndexResult <=", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultLike(String value) {
            addCriterion("IndexResult like", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultNotLike(String value) {
            addCriterion("IndexResult not like", value, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultIn(List<String> values) {
            addCriterion("IndexResult in", values, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultNotIn(List<String> values) {
            addCriterion("IndexResult not in", values, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultBetween(String value1, String value2) {
            addCriterion("IndexResult between", value1, value2, "indexResult");
            return (Criteria) this;
        }

        public Criteria andIndexResultNotBetween(String value1, String value2) {
            addCriterion("IndexResult not between", value1, value2, "indexResult");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNull() {
            addCriterion("CreateTime is null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNotNull() {
            addCriterion("CreateTime is not null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeEqualTo(Date value) {
            addCriterion("CreateTime =", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotEqualTo(Date value) {
            addCriterion("CreateTime <>", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThan(Date value) {
            addCriterion("CreateTime >", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("CreateTime >=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThan(Date value) {
            addCriterion("CreateTime <", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThanOrEqualTo(Date value) {
            addCriterion("CreateTime <=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIn(List<Date> values) {
            addCriterion("CreateTime in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotIn(List<Date> values) {
            addCriterion("CreateTime not in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeBetween(Date value1, Date value2) {
            addCriterion("CreateTime between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotBetween(Date value1, Date value2) {
            addCriterion("CreateTime not between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIsNull() {
            addCriterion("UpdateTime is null");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIsNotNull() {
            addCriterion("UpdateTime is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeEqualTo(Date value) {
            addCriterion("UpdateTime =", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotEqualTo(Date value) {
            addCriterion("UpdateTime <>", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeGreaterThan(Date value) {
            addCriterion("UpdateTime >", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("UpdateTime >=", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeLessThan(Date value) {
            addCriterion("UpdateTime <", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeLessThanOrEqualTo(Date value) {
            addCriterion("UpdateTime <=", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIn(List<Date> values) {
            addCriterion("UpdateTime in", values, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotIn(List<Date> values) {
            addCriterion("UpdateTime not in", values, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeBetween(Date value1, Date value2) {
            addCriterion("UpdateTime between", value1, value2, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotBetween(Date value1, Date value2) {
            addCriterion("UpdateTime not between", value1, value2, "updateTime");
            return (Criteria) this;
        }
    }

    /**
     * This class was generated by MyBatis Generator.
     * This class corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated do_not_delete_during_merge
     */
    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    /**
     * This class was generated by MyBatis Generator.
     * This class corresponds to the database table IndexAnalysisDetailResult
     *
     * @mbg.generated
     */
    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}