時間単位でエンティティを選択します。 日付と時刻を含むフィールド型DATEを持つOracle DBMSがあります。これは私のコードです。時間基準でデータを選択する方法は?Hibernate CriteriaとOracleを使用して、時間を使って作業するより良い方法は何ですか?
Calendar timeCal = new GregorianCalendar(0,0,0,0,0,0);
Date timeMin = timeCal.getTime();
timeCal.add(Calendar.HOUR_OF_DAY, 1);
Date timeMax = timeCal.getTime();
if (minDate != null && maxDate != null)
criteria.add(Restrictions.between("eventDate", minDate, maxDate));
if (onDate != null) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(onDate);
calendar.add(Calendar.DAY_OF_MONTH, 1);
criteria.add(Restrictions.between("eventDate", onDate, calendar.getTime()));
}
if(minTime!=null&&maxTime!=null){
/*
How to add Restriction on eventDate field, for time only?
if minTime is 3:00 and maxTime is 16:00, must to return
all rows having the time part of their eventDate between
3:00 and 16:00, regardless of the date part
*/
}
投稿したコードの問題点を教えてください。 –
実装されていませんminTime!= null && maxTime!= null式 – Selector
これらの基準が何であるか、およびクエリが何をすべきかはわかりません。 –