0

私は「クリエイティブ」クラスのすべての分野をカンパレするために次のceodeを持っています。一部のフィールドは日付です。

Criteria creativeCriteria = getSession().createCriteria(PcmCreative.class);
    for(Entry<String,Object> mapEntry : propValMap.entrySet()){
        if(mapEntry.getValue() == null){
            creativeCriteria.add(Restrictions.isNull(mapEntry.getKey()));
            //creativeCriteria.add(Restrictions.disjunction().add(Restrictions.isNull(mapEntry.getKey())).add(Restrictions.eq(mapEntry.getKey(),mapEntry.getValue())));
        }else{
            creativeCriteria.add(Restrictions.eq(mapEntry.getKey(),mapEntry.getValue()));
        }
    }
    creativeCriteria.createAlias("campaign", "c").add(Restrictions.eq("c.campaignNumber", campaignNumber));
    creativeCriteria.setProjection(Projections.rowCount());
    return (Integer)creativeCriteria.uniqueResult();

次のコードを使用して日付をフォーマットします:

   String strDate = DateUtils.convertDateToString((Date)     fieldValue,CmtConstants.CMTDATE_MYSQL_COMPARISION_FORMAT);
//fieldValue = DateUtils.convertStringToDate(strDate,CmtConstants.CMTDATE_MYSQL_COMPARISION_FORMAT);

ここで、CMTDATE_MYSQL_COMPARISION_FORMATは「yyyy-mm-dd」です。

しかし、比較は失敗します。SimpleDateFormat.parseメソッドを内部的に使用するDateUtils.convertStringToDateによって返される日付には、休止状態でのcritraiの同等性に失敗すると思われるGMT文字列も含まれています。GMT文字列を削除し、日付と時刻の部分のみを含む日付を取得する方法はありますか?

4

1 に答える 1

0

以下のように基準を追加する前に、日付形式を変換するユーティリティを作成する必要があります。

 private java.sql.Date getSQLDate(Object dateObj) {

    SimpleDateFormat sdf = null;
    try {

        sdf = new SimpleDateFormat("yyyy-mm-dd");
        java.util.Date utilDate = sdf.parse((String) dateObj);
        if (utilDate == null) {
            return null;
        } else {
            return new java.sql.Date(utilDate.getTime());
        }

    } catch (ParseException parseEx) {
       }

}
于 2012-09-13T11:48:17.280 に答える