Spring JPA 选择特定列

新手上路,请多包涵

我正在使用 Spring JPA 执行所有数据库操作。但是我不知道如何从 Spring JPA 中的表中选择特定列?

例如:

SELECT projectId, projectName FROM projects

原文由 user1817436 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 667
2 个回答

您可以在 @Query 注释中设置 nativeQuery = true --- 来自 Repository 类的注释,如下所示:

 public static final String FIND_PROJECTS = "SELECT projectId, projectName FROM projects";

@Query(value = FIND_PROJECTS, nativeQuery = true)
public List<Object[]> findProjects();

请注意,您必须自己进行映射。除非你真的只需要这两个值,否则像这样使用常规映射查找可能更容易:

 public List<Project> findAll()

也可能值得查看 Spring 数据 文档

原文由 Durandal 发布,翻译遵循 CC BY-SA 3.0 许可协议

您可以使用来自 Spring Data JPA (doc) 的投影。在您的情况下,创建界面:

 interface ProjectIdAndName{
    String getId();
    String getName();
}

并将以下方法添加到您的存储库

List<ProjectIdAndName> findAll();

原文由 mpr 发布,翻译遵循 CC BY-SA 3.0 许可协议

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