0

statusおよびOpenOn(日付)の 2 つのフィールドに対して動的ファインダーを使用して検索しようとしています。

render(view:'list', model:[incidentInstanceList:Incident.findAllByStatusIlikeAndOpenOnGreaterThan("closed",new Date()-7,[sort:"id",order:"desc"])]) 

上記のクエリは過去 7 日間を検索しますが、過去 7 日間ではなく「先週」を検索したいです。これどうやってするの?

4

1 に答える 1

1

次のようなものが必要になる場合があります。

def lastWeek
use(org.codehaus.groovy.runtime.TimeCategory) {
    lastWeek = new Date() - 1.week
}

render(view:'list', model: [incidentInstanceList: Incident.findAllByStatusIlikeAndOpenOnGreaterThan( "closed", lastWeek, [sort:"id", order: "desc"])] )

アップデート:

import java.util.Calendar
import groovy.time.TimeCategory

def roundToLastMonday(date) {
    Calendar cal=Calendar.getInstance();
    cal.setTime(date);
    cal.set(Calendar.DAY_OF_MONTH, cal.get(Calendar.DAY_OF_MONTH) - cal.get(Calendar.DAY_OF_WEEK) + Calendar.MONDAY)
    cal.getTime()
}

def getLastWeekRange() {
    def startDate, endDate
    use(TimeCategory) {
      startDate = roundToLastMonday(1.week.ago)
      endDate = startDate + 1.week - 1.second
    }
    [startDate, endDate]
}

def range = getLastWeekRange()
def result = Incident.withCriteria {
    like ("status", "closed")
    between ("open", range[0], range[1])
}
render(view:'list', model: [incidentInstanceList: result]
于 2011-08-26T08:47:36.073 に答える