JPA基準APIを使用して、日付ベースからレコードをフェッチします。 私はエンティティレコードフィールドdateTimeを持つことができます。私はコード:JPA criteria API order by NULL last
public List<Record> find(RecordFilter recordFilter, int page, int pageSize) {
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<Record> criteriaQuery = criteriaBuilder.createQuery(Record.class);
Root<Record> recordRoot = criteriaQuery.from(Record.class);
/*
* JOINS. Left Joins are used for optional fields, or fields inside of the optional fields.
*/
Join<Record, Agency> recordAgencyJoin = recordRoot.join(RecordTable.FIELD_AGENCY);
//Some other joins
//This is where I had the problem.
applyOrderBy(criteriaQuery, criteriaBuilder, recordRoot);
/*
* Specify which columns to select and their order.
* criteriaQuery.multiselect(....);
*/
applyMultiSelect(recordRoot, recordAgencyJoin, /*other joins*/ criteriaQuery);
/*
* criteriaQuery.where(somePredicate);
*/
applyFilter(recordFilter, criteriaQuery, criteriaBuilder,
recordRoot, recordAgencyJoin /*, other joins*/);
TypedQuery<Record> query = entityManager.<Record>createQuery(criteriaQuery);
RepositoryUtils.applyPagination(query, page, pageSize);
return query.getResultList();
}
private void applyOrderBy(CriteriaBuilder criteriaBuilder, Root<Record> recordRoot, CriteriaQuery<Record> criteriaQuery) {
//Other fields to be added to the final sort.
Order dateTimeDescOrder = criteriaBuilder.desc(recordRoot.get(RecordTable.FIELD_DATE_TIME));
criteriaQuery.orderBy(dateTimeDescOrder /*, other orders by*/);
}
NULL dateTimeFieldのレコードが最初に表示されます。 私はPostrgresデータベースを使用しています。 私は解決策を見つけたので、私はこの質問に答えます。 似たような投稿です。 JPA Criteria Query API and order by null last
これを試して、「エラー:タイムゾーンのないタイムスタンプとバイトアが一致しません」というエラーが表示されました。 'cb.coalesce(root.get( 'joinedModel')。get( 'someDate')、MIN_DATE)' –
本当に?それは私のコードで働いた。休止状態のバージョンMIN_DATEを確認してください。また、エンティティのリレーションをナビゲートする代わりにjoinメソッドを使用しましたrecordRoot = externalRoot.jolin( "recordRelation"); 次に、recordRoot.get( "field") –
発見された根本原因。私は日付とは対照的に 'LocalDateTime'を使用しました。 Postgres DBでは、これは動作しません。答えに指定されているように 'Date'に切り替えました。 –