-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
850f3b9
commit 54095a6
Showing
6 changed files
with
111 additions
and
320 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
27 changes: 27 additions & 0 deletions
27
src/main/java/com/github/lc/oss/commons/jpa/AbstractQueryBuilder.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
package com.github.lc.oss.commons.jpa; | ||
|
||
import java.util.ArrayList; | ||
|
||
import com.github.lc.oss.commons.serialization.Jsonable; | ||
|
||
import jakarta.persistence.criteria.CriteriaBuilder; | ||
import jakarta.persistence.criteria.CriteriaQuery; | ||
|
||
public abstract class AbstractQueryBuilder<Type extends Jsonable> { | ||
public CriteriaQuery<Type> forData(SearchCriteria searchCriteria, CriteriaBuilder criteriaBuilder) { | ||
QueryInfo info = this.build(searchCriteria, criteriaBuilder, false); | ||
CriteriaQuery<Type> query = info.getQuery(); | ||
query.select(info.getSelection()); | ||
return query; | ||
} | ||
|
||
public CriteriaQuery<Long> forCount(SearchCriteria searchCriteria, CriteriaBuilder criteriaBuilder) { | ||
QueryInfo info = this.build(searchCriteria, criteriaBuilder, true); | ||
CriteriaQuery<Long> query = info.getQuery(); | ||
query.orderBy(new ArrayList<>()); | ||
query.select(info.getSelection()); | ||
return query; | ||
} | ||
|
||
protected abstract <T> QueryInfo build(SearchCriteria searchCriteria, CriteriaBuilder criteriaBuilder, boolean forCount); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
26 changes: 26 additions & 0 deletions
26
src/main/java/com/github/lc/oss/commons/jpa/QueryInfo.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
package com.github.lc.oss.commons.jpa; | ||
|
||
import jakarta.persistence.criteria.CriteriaQuery; | ||
import jakarta.persistence.criteria.Selection; | ||
|
||
@SuppressWarnings("unchecked") | ||
public class QueryInfo { | ||
private Selection<?> selection; | ||
private CriteriaQuery<?> query; | ||
|
||
public <T> Selection<T> getSelection() { | ||
return (Selection<T>) this.selection; | ||
} | ||
|
||
public void setSelection(Selection<?> selection) { | ||
this.selection = selection; | ||
} | ||
|
||
public <T> CriteriaQuery<T> getQuery() { | ||
return (CriteriaQuery<T>) this.query; | ||
} | ||
|
||
public void setQuery(CriteriaQuery<?> query) { | ||
this.query = query; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.