注意事项:
1、与条件使用 &&
2、过滤条件queryTemplate 不能加上排序order by语句。解决方法是使用query.setOrdering("orderDate desc");
1、与条件使用 &&
2、过滤条件queryTemplate 不能加上排序order by语句。解决方法是使用query.setOrdering("orderDate desc");
public List<FanOrder> queryByUsername(String username,String startDate,String endDate){
List<FanOrder> orders = null;
Query query = null;
try {
String queryTemplate = "",filter="";
if (!username.equals("")){
queryTemplate = "username == \"%s\" && orderDate >= \"%s\" && orderDate <= \"%s\" ";
filter = String.format(queryTemplate,username,startDate, endDate);
}else{
queryTemplate = "orderDate >= \"%s\" && orderDate <= \"%s\" ";
filter = String.format(queryTemplate,startDate, endDate);
}
query = pm.newQuery(FanOrder.class,filter);
query.setOrdering("orderDate desc");
orders = (List<FanOrder>) query.execute();
} catch (RuntimeException e) {
e.printStackTrace();
}finally {
query.closeAll();
}
return orders;
}
本文介绍了一种优化后的FanOrder查询方法,通过使用条件连接符&&和动态设置排序方式,实现了根据用户名、开始日期和结束日期筛选订单的功能。
4241

被折叠的 条评论
为什么被折叠?



