首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Spring JPA选择特定列

Spring JPA选择特定列
EN

Stack Overflow用户
提问于 2014-02-25 15:25:26
回答 11查看 386.7K关注 0票数 190

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

例如:

SELECT projectId, projectName FROM projects

EN

回答 11

Stack Overflow用户

回答已采纳

发布于 2014-02-25 15:43:34

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

代码语言:javascript
复制
public static final String FIND_PROJECTS = "SELECT projectId, projectName FROM projects";

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

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

代码语言:javascript
复制
public List<Project> findAll()

同样值得一看的是Spring data docs

票数 95
EN

Stack Overflow用户

发布于 2016-12-02 22:07:57

您可以使用来自Spring Data JPA (doc)的投影。在您的示例中,创建接口:

代码语言:javascript
复制
interface ProjectIdAndName{
    String getId();
    String getName();
}

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

代码语言:javascript
复制
List<ProjectIdAndName> findAll();
票数 250
EN

Stack Overflow用户

发布于 2015-03-13 05:34:24

我不太喜欢它的语法(它看起来有点老套……)但这是我所能找到的最优雅的解决方案(它在JPA仓库类中使用了自定义的JPQL查询):

代码语言:javascript
复制
@Query("select new com.foo.bar.entity.Document(d.docId, d.filename) from Document d where d.filterCol = ?1")
List<Document> findDocumentsForListing(String filterValue);

当然,您只需为Document提供一个构造函数,该构造函数接受docId & filename作为构造函数参数。

票数 163
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22007341

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档