public interface CartQuery extends MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
MAX_OFFSET, MIN_OFFSET
Modifier and Type | Method and Description |
---|---|
static CartQuery |
of() |
CartQuery |
plusExpansionPaths(Function<CartExpansionModel<Cart>,ExpansionPathContainer<Cart>> m)
Creates a new object with the properties of the old object but adds a new expansion path to it by using meta models.
|
CartQuery |
plusPredicates(Function<CartQueryModel,QueryPredicate<Cart>> m)
Returns a new instance with the new predicate appended (AND semantics).
|
CartQuery |
plusPredicates(List<QueryPredicate<Cart>> queryPredicates)
Returns a new instance with the new predicate list appended to the existing predicates (AND semantic).
|
CartQuery |
plusPredicates(QueryPredicate<Cart> queryPredicate)
Returns a new instance with the new predicate appended to the existing predicates (AND semantic).
|
CartQuery |
plusSort(Function<CartQueryModel,QuerySort<Cart>> m)
Returns a query with the sort expression appended to the existing ones.
|
CartQuery |
plusSort(List<QuerySort<Cart>> sort)
Returns a query with the sort expressions appended to the existing ones.
|
CartQuery |
plusSort(QuerySort<Cart> sort)
Returns a query with the sort expression appended to the existing ones.
|
static com.fasterxml.jackson.core.type.TypeReference<PagedQueryResult<Cart>> |
resultTypeReference()
Creates a container which contains the full Java type information to deserialize the query result (NOT this class) from JSON.
|
CartQuery |
withExpansionPaths(Function<CartExpansionModel<Cart>,ExpansionPathContainer<Cart>> m)
Creates a new object with the properties of the old object but replaces all expansion paths with a single
expansionPath by using meta models. |
CartQuery |
withFetchTotal(boolean fetchTotal)
Enables/disables a flag it the total amount of items should be counted.
|
CartQuery |
withLimit(Long limit)
Creates a new instance which a limited amount of results.
|
CartQuery |
withOffset(Long offset)
Returns a new query with the new offset as offset.
|
CartQuery |
withPredicates(Function<CartQueryModel,QueryPredicate<Cart>> predicateFunction)
Returns a new instance with the new predicate as only predicate.
|
CartQuery |
withPredicates(List<QueryPredicate<Cart>> queryPredicates)
Returns a new instance with the new predicate list as predicates.
|
CartQuery |
withPredicates(QueryPredicate<Cart> queryPredicate)
Returns a new instance with the new predicate as only predicate.
|
CartQuery |
withSort(Function<CartQueryModel,QuerySort<Cart>> m)
Returns a query with the new sort as only sort parameter.
|
CartQuery |
withSort(List<QuerySort<Cart>> sort)
Returns a query with the new sort list as only sort parameters.
|
CartQuery |
withSort(QuerySort<Cart> sort)
Returns a query with the new sort as only sort parameter.
|
CartQuery |
withSortMulti(Function<CartQueryModel,List<QuerySort<Cart>>> m)
Returns a query with the new sort list as only sort parameters.
|
plusPredicates, plusSort, withPredicates, withQueryParam, withSort
withLimit, withOffset
endpoint, expansionPaths, fetchTotal, limit, offset, predicates, sort
deserialize, toQuery
canDeserialize, httpRequestIntent
plusExpansionPaths, plusExpansionPaths, plusExpansionPaths, plusExpansionPaths, withExpansionPaths, withExpansionPaths, withExpansionPaths, withExpansionPaths
static com.fasterxml.jackson.core.type.TypeReference<PagedQueryResult<Cart>> resultTypeReference()
static CartQuery of()
CartQuery plusPredicates(Function<CartQueryModel,QueryPredicate<Cart>> m)
MetaModelQueryDsl
plusPredicates
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
m
- function given a meta model description of the model return a QueryPredicate
MetaModelQueryDsl.withPredicates(Function)
CartQuery plusPredicates(QueryPredicate<Cart> queryPredicate)
QueryDsl
plusPredicates
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
plusPredicates
in interface QueryDsl<Cart,CartQuery>
queryPredicate
- the new predicateQueryDsl.withPredicates(QueryPredicate)
CartQuery plusPredicates(List<QueryPredicate<Cart>> queryPredicates)
QueryDsl
plusPredicates
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
plusPredicates
in interface QueryDsl<Cart,CartQuery>
queryPredicates
- the new predicate listQueryDsl.withPredicates(List)
CartQuery plusSort(Function<CartQueryModel,QuerySort<Cart>> m)
MetaModelQueryDsl
plusSort
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
m
- function given a meta model description of the model returns a list of QuerySort
MetaModelQueryDsl.withSort(Function)
CartQuery plusSort(List<QuerySort<Cart>> sort)
QueryDsl
plusSort
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
plusSort
in interface QueryDsl<Cart,CartQuery>
sort
- sort expressions how the results of the query should be sortedQueryDsl.withSort(List)
CartQuery plusSort(QuerySort<Cart> sort)
QueryDsl
plusSort
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
plusSort
in interface QueryDsl<Cart,CartQuery>
sort
- sort expression how the results of the query should be sortedQueryDsl.withSort(QuerySort)
CartQuery withPredicates(Function<CartQueryModel,QueryPredicate<Cart>> predicateFunction)
MetaModelQueryDsl
withPredicates
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
predicateFunction
- function given a meta model description of the model return a QueryPredicate
MetaModelQueryDsl.plusPredicates(Function)
CartQuery withPredicates(QueryPredicate<Cart> queryPredicate)
QueryDsl
withPredicates
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
withPredicates
in interface QueryDsl<Cart,CartQuery>
queryPredicate
- the new predicateQueryDsl.plusPredicates(QueryPredicate)
CartQuery withPredicates(List<QueryPredicate<Cart>> queryPredicates)
QueryDsl
withPredicates
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
withPredicates
in interface QueryDsl<Cart,CartQuery>
queryPredicates
- the new predicate listQueryDsl.plusPredicates(List)
CartQuery withSort(Function<CartQueryModel,QuerySort<Cart>> m)
MetaModelQueryDsl
withSort
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
m
- function given a meta model description of the model returns a QuerySort
MetaModelQueryDsl.plusSort(Function)
CartQuery withSort(List<QuerySort<Cart>> sort)
QueryDsl
withSort
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
withSort
in interface QueryDsl<Cart,CartQuery>
sort
- list of sorts how the results of the query should be sortedQueryDsl.plusSort(List)
CartQuery withSort(QuerySort<Cart> sort)
QueryDsl
withSort
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
withSort
in interface QueryDsl<Cart,CartQuery>
sort
- sort expression how the results of the query should be sortedQueryDsl.plusSort(QuerySort)
CartQuery withSortMulti(Function<CartQueryModel,List<QuerySort<Cart>>> m)
MetaModelQueryDsl
withSortMulti
in interface MetaModelQueryDsl<Cart,CartQuery,CartQueryModel,CartExpansionModel<Cart>>
m
- function given a meta model description of the model returns a list of QuerySort
MetaModelQueryDsl.plusSort(List)
,
MetaModelQueryDsl.withSort(Function)
CartQuery plusExpansionPaths(Function<CartExpansionModel<Cart>,ExpansionPathContainer<Cart>> m)
MetaModelReferenceExpansionDsl
An example in the product projection context:
final ProductProjectionByIdGet fetch1 = ProductProjectionByIdGet.of("id", ProductProjectionType.CURRENT) .plusExpansionPaths(m -> m.categories()); assertThat(fetch1.expansionPaths()) .isEqualTo(asList(ExpansionPath.of("categories[*]"))); final ProductProjectionByIdGet fetch2 = fetch1.plusExpansionPaths(m -> m.productType()); assertThat(fetch2.expansionPaths()) .isEqualTo(asList(ExpansionPath.of("categories[*]"), ExpansionPath.of("productType"))) .isEqualTo(listOf(fetch1.expansionPaths(), ExpansionPath.of("productType"))); //this is equivalent to final ExpansionPath<ProductProjection> categoryExpand = ProductProjectionExpansionModel.of().categories().expansionPaths().get(0); final ExpansionPath<ProductProjection> productTypeExpand = ProductProjectionExpansionModel.of().productType().expansionPaths().get(0); final ProductProjectionByIdGet fetchB = ProductProjectionByIdGet.of("id", ProductProjectionType.CURRENT) .withExpansionPaths(asList(categoryExpand, productTypeExpand)); assertThat(fetchB.expansionPaths()) .isEqualTo(asList(ExpansionPath.of("categories[*]"), ExpansionPath.of("productType")));
See the test code.
plusExpansionPaths
in interface MetaModelReferenceExpansionDsl<Cart,CartQuery,CartExpansionModel<Cart>>
m
- function to use the meta model for expansions to create an expansion pathCartQuery withExpansionPaths(Function<CartExpansionModel<Cart>,ExpansionPathContainer<Cart>> m)
MetaModelReferenceExpansionDsl
expansionPath
by using meta models.
An example in the product projection context:
final ProductProjectionByIdGet fetch = ProductProjectionByIdGet.of("id", ProductProjectionType.CURRENT) .plusExpansionPaths(ProductProjectionExpansionModel.of().categories()); assertThat(fetch.expansionPaths()) .isEqualTo(asList(ExpansionPath.of("categories[*]"))); final ProductProjectionByIdGet fetch2 = fetch.withExpansionPaths(m -> m.productType()); assertThat(fetch.expansionPaths()).overridingErrorMessage("old object is unchanged") .isEqualTo(asList(ExpansionPath.of("categories[*]"))); assertThat(fetch2.expansionPaths()).isEqualTo(asList(ExpansionPath.of("productType"))); assertThat(fetch2).isNotSameAs(fetch);
See the test code.
withExpansionPaths
in interface MetaModelReferenceExpansionDsl<Cart,CartQuery,CartExpansionModel<Cart>>
m
- function to use the meta model for expansions to create an expansion pathCartQuery withFetchTotal(boolean fetchTotal)
QueryDsl
If fetchTotal
is true then PagedQueryResult.getTotal()
is null.
withFetchTotal
in interface QueryDsl<Cart,CartQuery>
fetchTotal
- enable the total count if true (default on the construction of the QueryDsl).QueryDsl
as this instance but with the updated flagCartQuery withLimit(Long limit)
QueryDsl
withLimit
in interface QueryDsl<Cart,CartQuery>
limit
- the maximum amount of items of T
which should be included in the PagedQueryResult
.PagedQueryResult.getResults()
CartQuery withOffset(Long offset)
QueryDsl
withOffset
in interface QueryDsl<Cart,CartQuery>
offset
- the number of items which should be omitted in the query result.