【问题标题】:Query map value with SpringData and QueryDSL-JPA使用 SpringData 和 QueryDSL-JPA 查询地图值
【发布时间】:2017-12-22 02:17:44
【问题描述】:

我得到了以下数据结构

@Entity
public class Publication {
   private Map<Integer, Author> authors;
   // more stuff
}

@Entity
public class Author {
   private String name;
   // more stuff
}

我正在寻找一个查询 dsl 谓词,它提供我的所有出版物,其中任何 Author.name 包含某个字符串,例如“汉斯”

我试过了:

QPublication publication = QPublication.publication;
QAuthor author = QAuthor.author;
publication.authors.containsValue(JPAExpressions.selectFrom(author).where(author.lastName.containsIgnoreCase("Hans")));

但是,如果有多个作者的名字中包含“Hans”,这会报错。有没有像 publication.authors.anyValue().name.equalsIgrnoreCase("Hans") 这样的东西?

【问题讨论】:

    标签: java jpa spring-data querydsl


    【解决方案1】:

    我找到了一个带有连接和自定义存储库实现的解决方案:

    public class PublicationRepositoryImpl extends QueryDslRepositorySupport 
       implements PublicationRepositoryCustom {
    
    @Override
    public Page<Publication> findByAnyAuthorName(String name, PageRequest pageRequest) {
       QPublication publication = QPublication.publication;
       JPQLQuery<Publication> query = from(publication);
       QAuthor author = QAuthor.author;
       query.join(publication.authors, author);
       query.where(author.name.containsIgnoreCase(name);
       JPQLQuery<Publication> pagedQuery = getQuerydsl()
          .applyPagination(pageRequest, query);
    
       return PageableExecutionUtils.getPage(pagedQuery.fetch(), pageRequest,
        () -> query.fetchCount());
    }
    

    【讨论】:

      【解决方案2】:

      我认为你错过了 BooleanBuilder

      在您的存储库中 - 试试这个

      QPublication publication = QPublication.publication;
      QAuthor author = QAuthor.author;
      BooleanBuilder where= new BooleanBuilder();
      where.and(publication.author.name.containsIgnoreCase(textToSearch));
      
      //pass the where condition to the desired Repo method
      repo.findAll(where);
      

      【讨论】:

      • 因为Publication.authors是一张地图,所以没有publication.author如果你只有一个条件就不需要BoolenBuilder
      猜你喜欢
      • 2016-09-12
      • 1970-01-01
      • 2017-04-06
      • 2021-03-14
      • 2014-03-29
      • 1970-01-01
      • 2018-11-12
      • 2012-07-25
      • 2016-07-02
      相关资源
      最近更新 更多