在检查集合对象
中的日期字段中的空指针时,我遇到了一种奇怪的行为public class FilterTest {
public static void main(String[] args) {
Collection<EmployeeDto> employees = new ArrayList<EmployeeDto>();
employees.add(new EmployeeDto("", 1111, new Date()));
employees.add(new EmployeeDto("123", 2222, null));
employees.add(new EmployeeDto("22", 3333, new Date()));
employees.add(new EmployeeDto("22", 4444, null));
employees.add(new EmployeeDto("11", 5555, null));
employees.add(new EmployeeDto("22", 6666, null));
employees.add(new EmployeeDto(null, 6666,null));
StandardEvaluationContext stdContext = new StandardEvaluationContext();
stdContext.setVariable("emps", employees);
ExpressionParser parser = new SpelExpressionParser();
**String key4= "#emps.?[dateOfBirth != null ? T(DateUtil).formatDate(dateOfBirth), 'dd/MM/yyyy').contains('25/07/2012') : false]" ;**
Collection<Object> proj1 = (Collection<Object>) parser.parseExpression(
key4).getValue(stdContext);
System.out.println(proj1);
}
class EmployeeDto {
String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
int age;
Date dateOfBirth;
public EmployeeDto(String name, int age, Date dateOfBirth) {
this.name = name;
this.age = age;
this.dateOfBirth = dateOfBirth;
}
public Date getDateOfBirth() {
return dateOfBirth;
}
public void setDateOfBirth(Date dateOfBirth) {
this.dateOfBirth = dateOfBirth;
}
}
表达式应返回满足条件的对象集合。但现在,我得到一个例外,即null无法找到dateOfBirth。所以我尝试了一个新的表达式
String key4= "#emps.?[dateOfBirth != null ? T(DateUtil).formatDate(#emps.![dateOfBirth], 'dd/MM/yyyy').contains('25/07/2012') : false]" ;
这很好用。但是当我在集合的第一个对象中添加null时,它将结果返回为0,当我检查时,我发现null被传递给DateUtil类formatDate方法。即员工集合就像 `
employees.add(new EmployeeDto("", 1111, null)); // first value is null, and I am getting empty result, but there is one corrrect result
**employees.add(new EmployeeDto("12", 2222, null));**
employees.add(new EmployeeDto("22", 3333, new Date()));
employees.add(new EmployeeDto("33", 4444, null));
employees.add(new EmployeeDto("FIVE", 5555, null));
employees.add(new EmployeeDto("SIX", 6666, null));
employees.add(new EmployeeDto(null, 6666,null));
请你帮我解决这个问题,有人能说出我应该使用的正确表达吗?
答案 0 :(得分:0)
在DateUtil类中,添加如下方法:
public static boolean isSameDay(Date date1, Date date2) {
if (date1 == null || date2 == null) {
return false;
}
Calendar cal1 = Calendar.getInstance();
cal1.setTime(date1);
Calendar cal2 = Calendar.getInstance();
cal2.setTime(date2);
return isSameDay(cal1, cal2);
}
然后就这样做:
StandardEvaluationContext stdContext = new StandardEvaluationContext();
stdContext.setVariable("emps", employees);
stdContext.setVariable("yourTestDate", new Date());
ExpressionParser parser = new SpelExpressionParser();
String key4 = "#emps.?[T(DateUtil).isSameDate(dateOfBirth, yourTestDate)]" ;
Collection<Object> proj1 = (Collection<Object>) parser.parseExpression(key4).getValue(stdContext);
System.out.println(proj1);
答案 1 :(得分:0)
前几天你问了一个类似的问题 - 在这种情况下,你需要对集合选择的结果进行预测。这是一个更简单的例子......
Expression exp = new SpelExpressionParser()
.parseExpression("(#emps.?[name != null]).![name.toUpperCase()]");
第一部分(...)选择符合标准的元素;然后它会对新系列进行投影。