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

com.github.antelopeframework.mybatis.criterion.Criteria Maven / Gradle / Ivy

There is a newer version: 1.1.5
Show newest version
package com.github.antelopeframework.mybatis.criterion;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import lombok.Getter;

/**
 * Criteria is a simplified API for retrieving entities by composing
 * Criterion objects. This is a very convenient approach for
 * functionality like "search" screens where there is a variable number of
 * conditions to be placed upon the result set.
*
* The method Criteria.createCriteria() is a factory for * Criteria. Criterion instances are usually obtained via the * factory methods on Restrictions. eg. * *
 * Criteria criteria = Criteria.createCriteria(Cat.class)
 * 	.add(Restrictions.ilike("name", "Iz%"))
 * 	.add(Restrictions.gt("weight", new Float(minWeight)))
 * 	.addOrder(Order.asc("age"));
 * 
* * @see Criteria#createCriteria() * @see com.github.antelopeframework.mybatis.criterion.Restrictions * @see com.github.antelopeframework.mybatis.criterion.Order * @see com.github.antelopeframework.mybatis.criterion.Criterion * * @author yangzhi.yzh */ @Getter public class Criteria implements Serializable { private static final long serialVersionUID = 1L; private final List criterionEntries = new ArrayList(); private final List orderEntries = new ArrayList(); private Integer maxResults = 0; private Integer firstResult = 0; private Criteria() {} /** * Create {@link Criteria} instance * * @return The criteria instance for manipulation and execution */ public static Criteria createCriteria() { return new Criteria(); } /** * 是否为无条件查询; 无条件查询会对表进行全量查询, 极度损耗性能; 在findByCriteria方法时, 最好判断一下是否为无条件查询. * * @return */ public boolean isNoConditionQuery() { return criterionEntries.size() == 0; } /** * Add a {@link Criterion restriction} to constrain the results to be retrieved. * * @param criterion The {@link Criterion criterion} object representing the restriction to be applied. * @return this (for method chaining) */ public Criteria add(Criterion expression) { add(this, expression); return this; } /** * Add an {@link Order ordering} to the result set. * * @param order The {@link Order order} object representing an ordering to be applied to the results. * @return this (for method chaining) */ public Criteria addOrder(Order ordering) { orderEntries.add(new OrderEntry(ordering, this)); return this; } /** * * @param maxResults * @return */ public Criteria setMaxResults(int maxResults) { if (maxResults > 0) { this.maxResults = maxResults; } return this; } public Criteria setFirstResult(int firstResult) { if (firstResult > 0) { this.firstResult = firstResult; } return this; } public Iterator iterateExpressionEntries() { return criterionEntries.iterator(); } public Iterator iterateOrderings() { return orderEntries.iterator(); } private Criteria add(Criteria criteriaInst, Criterion expression) { criterionEntries.add(new CriterionEntry(expression, criteriaInst)); return this; } @Getter public static final class CriterionEntry implements Serializable { private static final long serialVersionUID = 1L; private final Criterion criterion; private final Criteria criteria; private CriterionEntry(Criterion criterion, Criteria criteria) { this.criteria = criteria; this.criterion = criterion; } @Override public String toString() { return criterion.toString(); } } @Getter public static final class OrderEntry implements Serializable { private static final long serialVersionUID = 1L; private final Order order; private final Criteria criteria; private OrderEntry(Order order, Criteria criteria) { this.criteria = criteria; this.order = order; } @Override public String toString() { return order.toString(); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy