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

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

阅读 18.3k
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...(...);

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏