spring data jpa怎么做到只查询部分字段而不返回全部字段?

假设我新建一个user 下有4个字段,id,用户名,密码,地址。
spring data jpa 怎么做到只查询用户名和密码这两个字段呢?
(实际开发的表有20多个字段,查询返回一个月的记录所有字段的话要12秒,而我的需求只需要表中的3个字段,sql查询返回一个月的记录只需0.0083s)

阅读 18.8k
2 个回答

使用 spring-data 的 projection 即可:

public interface UserDto {
  Integer getId();
  String getUsername();
  String getPassword();
}

public interface UserRepository extends JpaRepository<User, Integer> {
  // smart way
  List<UserDto> findBy...(...);

  // 或者使用自定义查询
  @Query("select id, username, password from User where ...")
  List<UserDto> findUserDto(...);
}
  // smart way
  List<UserDto> findBy...(...);

这个方法的返回的是所有字段吧?