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

io.ebean.Filter Maven / Gradle / Ivy

There is a newer version: 15.8.1
Show newest version
package io.ebean;

import org.jspecify.annotations.NullMarked;

import java.util.List;
import java.util.Set;

/**
 * Provides support for filtering and sorting lists of entities without going
 * back to the database.
 * 

* That is, it uses local in-memory sorting and filtering of a list of entity * beans. It is not used in a Database query or invoke a Database query. *

*

* You can optionally specify a sortByClause and if so, the sort will always * execute prior to the filter expressions. You can specify any number of filter * expressions and they are effectively joined by logical "AND". *

*

* The result of the filter method will leave the original list unmodified and * return a new List instance. *

*

*

{@code
 *
 * // get a list of entities (query execution statistics in this case)
 *
 * List list =
 *     DB.find(MetaQueryStatistic.class).findList();
 *
 * long nowMinus24Hrs = System.currentTimeMillis() - 24 * (1000 * 60 * 60);
 *
 * // sort and filter the list returning a filtered list...
 *
 * List filteredList =
 *     DB.filter(MetaQueryStatistic.class)
 *         .sort("avgTimeMicros desc")
 *         .gt("executionCount", 0)
 *         .gt("lastQueryTime", nowMinus24Hrs)
 *         .eq("autoTuned", true)
 *         .maxRows(10)
 *         .filter(list);
 *
 * }
*

* The propertyNames can traverse the object graph (e.g. customer.name) by using * dot notation. If any point during the object graph traversal to get a * property value is null then null is returned. *

*

*

{@code
 *
 * // examples of property names that
 * // ... will traverse the object graph
 * // ... where customer is a property of our bean
 *
 * customer.name
 * customer.shippingAddress.city
 *
 * }
*

*

{@code
 *
 * // get a list of entities (query execution statistics)
 *
 * List orders =
 *     DB.find(Order.class).findList();
 *
 * // Apply a filter...
 *
 * List filteredOrders =
 *     DB.filter(Order.class)
 *         .startsWith("customer.name", "Rob")
 *         .eq("customer.shippingAddress.city", "Auckland")
 *         .filter(orders);
 *
 * }
* * @param the entity bean type */ @NullMarked public interface Filter { /** * Specify a sortByClause. *

* The sort (if specified) will always execute first followed by the filter * expressions. *

*

* Refer to {@link DB#sort(List, String)} for more detail. *

*/ Filter sort(String sortByClause); /** * Specify the maximum number of rows/elements to return. */ Filter maxRows(int maxRows); /** * Equal To - property equal to the given value. */ Filter eq(String prop, Object value); /** * Not Equal To - property not equal to the given value. */ Filter ne(String propertyName, Object value); /** * Case Insensitive Equal To. */ Filter ieq(String propertyName, String value); /** * Between - property between the two given values. */ Filter between(String propertyName, Object value1, Object value2); /** * Greater Than - property greater than the given value. */ Filter gt(String propertyName, Object value); /** * Greater Than or Equal to - property greater than or equal to the given * value. */ Filter ge(String propertyName, Object value); /** * Less Than - property less than the given value. */ Filter lt(String propertyName, Object value); /** * Less Than or Equal to - property less than or equal to the given value. */ Filter le(String propertyName, Object value); /** * Is Null - property is null. */ Filter isNull(String propertyName); /** * Is Not Null - property is not null. */ Filter isNotNull(String propertyName); /** * Starts With. */ Filter startsWith(String propertyName, String value); /** * Case insensitive Starts With. */ Filter istartsWith(String propertyName, String value); /** * Ends With. */ Filter endsWith(String propertyName, String value); /** * Case insensitive Ends With. */ Filter iendsWith(String propertyName, String value); /** * Contains - property contains the string "value". */ Filter contains(String propertyName, String value); /** * Case insensitive Contains. */ Filter icontains(String propertyName, String value); /** * In - property has a value contained in the set of values. */ Filter in(String propertyName, Set values); /** * Apply the filter to the list returning a new list of the matching elements * in the sorted order. *

* The sourceList will remain unmodified. *

* * @return Returns a new list with the sorting and filters applied. */ List filter(List sourceList); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy