[size=medium]要查询如下图的[color=red]创建时间是2013-02-19 17:14:39[/color]一条文件信息:[/size]
[size=small]图一[/size]
[img]http://dl.iteye.com/upload/attachment/0080/6121/61e51192-bb15-36eb-a17b-8bdcbffc795c.bmp[/img]
[size=medium]查询条件如下图:[/size]
[size=small]图二[/size]
[img]http://dl.iteye.com/upload/attachment/0080/6125/2875ab1f-6bb9-365a-9e46-7a123d19c0c5.bmp[/img]
[size=medium]从输入的查询条件来看,我们应该可以查到这条文件信息的。但是点击查询按钮,是查不到数据的,原因是传到后台的时间参数是2013-02-18 00:00:00.0和 2013-02-19 00:00:00.0 图三展示了控制台打印的sql语句。[/size]
[size=small]图三[/size]
[img]http://dl.iteye.com/upload/attachment/0080/6123/1810e12e-912c-313a-9cc2-aa1ce44bd8de.bmp[/img]
[size=medium]显而易见,2013-02-19 17:14:39是不在输入的查询条件[b]2013-02-18 00:00:00.0和 2013-02-19 00:00:00.0[/b] 之间的。为了解决这个问题,只要输入的查询条件传入后台的参数值变为[b]2013-02-18 00:00:00.0和 [color=red]2013-02-19 23:59:59.0[/color] [/b] 这样就可以解决了。
那么后台的代码如何处理呢?如下
[/size]
[b][size=medium]DateUtil.java[/size][/b]
[size=small]图一[/size]
[img]http://dl.iteye.com/upload/attachment/0080/6121/61e51192-bb15-36eb-a17b-8bdcbffc795c.bmp[/img]
[size=medium]查询条件如下图:[/size]
[size=small]图二[/size]
[img]http://dl.iteye.com/upload/attachment/0080/6125/2875ab1f-6bb9-365a-9e46-7a123d19c0c5.bmp[/img]
[size=medium]从输入的查询条件来看,我们应该可以查到这条文件信息的。但是点击查询按钮,是查不到数据的,原因是传到后台的时间参数是2013-02-18 00:00:00.0和 2013-02-19 00:00:00.0 图三展示了控制台打印的sql语句。[/size]
[size=small]图三[/size]
[img]http://dl.iteye.com/upload/attachment/0080/6123/1810e12e-912c-313a-9cc2-aa1ce44bd8de.bmp[/img]
[size=medium]显而易见,2013-02-19 17:14:39是不在输入的查询条件[b]2013-02-18 00:00:00.0和 2013-02-19 00:00:00.0[/b] 之间的。为了解决这个问题,只要输入的查询条件传入后台的参数值变为[b]2013-02-18 00:00:00.0和 [color=red]2013-02-19 23:59:59.0[/color] [/b] 这样就可以解决了。
那么后台的代码如何处理呢?如下
[/size]
// 查询、快速过滤
@Override
public PageInfo<Document> searchDispatchDocuments(
SearchDocumentVo searchDocumentVo, Integer page, Integer rows,
String sidx, String sord) {
PageInfo<Document> pageInfo = null;
try {
[color=red]setProperties(searchDocumentVo);[/color]
pageInfo = dispatchDocumentsDao.searchDispatchDocuments(
searchDocumentVo, page, rows, sidx, sord);
} catch (Exception e) {
logger.error("异常信息", e);
throw new ServiceException(e);
}
return pageInfo;
}
[color=red]private void setProperties(SearchDocumentVo searchDocumentVo) {
if(null!=searchDocumentVo.getCreateDateEnd()){
searchDocumentVo.setCreateDateEnd(DateUtil
.getDateAtLastSecond(searchDocumentVo.getCreateDateEnd()));
}
[/color]
[b][size=medium]DateUtil.java[/size][/b]
/**
* 得到当天的23:59:59
* @param date
* @return
*/
[color=red]public static Date getDateAtLastSecond(Date date) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.set(Calendar.HOUR_OF_DAY, 23);
calendar.set(Calendar.MINUTE, 59);
calendar.set(Calendar.SECOND, 59);
return calendar.getTime();[/color]
}