JPA Spring - 过滤日期

问题描述 投票:3回答:2

可以过滤日期吗?例如,我只想选择过去30天的数据?选择应该是从现在到现在 - 30天。我会在没有查询的情况下优先选择解决方案。

@Service 
public class PersonService { 

   @Autowired 
   private PersonRepository personRepository;         
   public Stream<Person> all(Person mysearch){ 
       return personRepository 
              .findAll(Example.of(mysearch)) 
              .stream() 
              .map(Person::fromPerson); 
  } 
}

班级人员:

public class Person { 

    public Integer index; 
    public String firstname; 
    public String lastname; 
    @JsonFormat(pattern="dd.MM.yyyy") 
    public Date exdate; 
    public String insnr; 

    private Person(Integer index, String firstname, String lastname, Date exdate, String insnr){ 
        this.index=index; 
        this.firstname=firstname; 
        this.lastname=lastname; 
        this.exdate=exdate; 
        this.insnr=insnr; 
    } 

    public static Person fromPerson(Person person){ 
        return person == null ? null : new Person(person.getIndex(), person.getFirstname(), person.getLastname(), person.getExdate(), person.getInsnr()); 
    } 
} 

控制器:

@Autowired 
   private PersonService personService; 
   @RequestMapping(value="/person/list/**") 
   public List<Person> loadPersonList(   
                   @RequestParam(value = "insnr" ,required=false) String insnr) throws ParseException {         
       mysearch.setInsnr(insnr); 
       return personService.all(mysearch).collect(Collectors.toList()); 
   } 
java spring spring-data-jpa autowired
2个回答
0
投票
Calendar cal = Calendar.getInstance();
cal.setTime(dateInstance);
cal.add(Calendar.DATE, -30);
Date dateBefore30Days = cal.getTime();    
 public Stream<Person> all(Person mysearch){ 
       return personRepository 
              .findAll(Example.of(mysearch)).stream().filter(person -> person.getExdate().compareTo(dateBefore30Days) > 0)
                .map(Person::fromPerson)                       
                .findAny()
                .orElse(""); }

2
投票

Spring JPA存储库支持GreaterThan关键字queries

你可以考虑这样的事情:

LocalDate dateBefore30Days = LocalDate.now().minusDays(30);

List<Person> persons =  personRepository.findByExdateGreaterThan(dateBefore30Days);
© www.soinside.com 2019 - 2024. All rights reserved.