【问题标题】:QueryDsl how to use exist() to return booleanQueryDsl如何使用exist()返回布尔值
【发布时间】:2021-03-02 17:38:13
【问题描述】:

我想将 queryDsl 从版本 3 升级到版本 4。 但我对存在()有一个问题 在 QueryDsl 3 中存在返回一个布尔值,但在 QUEeryDSL 4 中它返回一个 BooleanOperation。 就我而言,我真的想要布尔值,但我不知道如何检索它。

我发现的最佳解决方案是这样做

.fetchCount() >0 

但我想知道是否存在其他(更好的)解决方案。

【问题讨论】:

    标签: java querydsl


    【解决方案1】:

    另一种选择是:

    queryFactory.select(queryField).from(qTable)
                .where(queryField.eq(value))
                .groupBy(queryField)
                .having(qTable.uuid.count().gt(0))
                .fetchOne() != null;
    

    这会将大于责任传递给查询。但是它可能不太可读,因此取决于更好的要求。

    【讨论】:

      猜你喜欢
      • 2018-01-12
      • 2023-03-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-04-07
      • 2013-08-18
      相关资源
      最近更新 更多