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

发布于 2022-09-11 14:35:49 字数 158 浏览 35 评论 0

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

风启觞 2022-09-18 14:35:49
  // smart way
  List<UserDto> findBy...(...);

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

悲欢浪云 2022-09-18 14:35:49

使用 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(...);
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文