java - 使用 Spring JPA 查询过滤数据

标签 java spring hibernate spring-data-jpa jpql

我有个人,我只想获取以某个字母开头的人(该字母来自输入字段)。我已经收到查询,但无法“使用”它。 我怎样才能做到这一点?

存储库:

@Repository
public interface PersonRepository extends JpaRepository<Person, Integer>{

    @Query("From Person where firstname like CONCAT(:firstname,'%')")
    Stream<Person> findAllWithSearchParams(@Param("firstname") String firstname);


}

服务:

@Service 
public class PersonService { 

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

类(class)人员:

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()); 
    } 
} 

Controller :

@Autowired 
   private PersonService personService; 
   @RequestMapping(value="/person/list/**") 
   public List<Person> loadPersonList(   
                   @RequestParam(value = "firstname" ,required=false) String firstname) throws ParseException {         
       mysearch.setFirstname(firstname); 
       return personService.all(mysearch).collect(Collectors.toList()); 
   } 

最佳答案

如果我理解正确的话,您需要一个查询来查找以某个字母或单词开头的人。所以,你只需要:

@Repository
public interface PersonRepository extends CrudRepository<Person, Integer> {

    List<Person> findByFirstnameStartingWith(String firstname);

}

关于java - 使用 Spring JPA 查询过滤数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48317090/

相关文章:

Java 不会使用 FileWriter 写入现有文件

java - lwjgl isKeyDown 取消其他键

java - 测试 Spring Integration 未设置 IntegrationFlows

java - hibernate 升级 : StatisticsService()

java - 如何使用 cURL 来使用以字节为参数的 Apache CXF Web 服务?

java - Spring Reactor 线程模型

java - 如何在Spring集成中推迟消息的消费

java - 没有实体管理器错误 JPA/hibernate 的持久性提供程序

java - 如何使用 Hibernate 将 ORM 转换为其子类?

java - 在大容量环境中解析 HTML 的最佳方法是什么?