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

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

阅读 5k
评论 2018-10-16 提问
    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(...);
    }
    评论 赞赏 2018-10-22
        // smart way
        List<UserDto> findBy...(...);

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

      评论 赞赏 2019-09-20
        撰写回答

        登录后参与交流、获取后续更新提醒