Querydsl / MySQL上的Count(*)(星号)?

时间:2014-11-22 09:22:27

标签: java mysql querydsl

原始的功能性MySQL查询,它列出了所有列出标签的所有提供商:

SELECT * FROM provider
  INNER JOIN provider_tag
  ON provider_tag.provider_id = provider.id AND provider_tag.tag_id in (1, 2)
  GROUP BY (provider.id)
  HAVING COUNT(*) = 2

在Querydsl中转换为MySQLQuery非常简单......

MySQLQuery query = new MySQLQuery(conn, dialect);

List<Integer> tagIds = ...;

query.from(provider)
    .innerJoin(provider_tag)
    .on(providerTag.providerId.eq(provider.id), providerTag.tagId.in(tagIds))
    .groupBy(provider.id)
    .having(???);

... having中的条件除外。

如何在查询中添加COUNT(*)

在Timo的第一次更正提案之后编辑

因此,查询如下所示:

SearchResults<Tuple> result = query.from(provider)
    .innerJoin(providerTag)
    .on(providerTag.providerId.eq(provider.id), providerTag.tagId.in(tagIds))
    .groupBy(provider.id)
    .having(Wildcard.count.eq((long) tagIds.size()))
    .listResults(
        provider.id,
        provider.name);

但是,如果结果集为空,则会导致SQLException Illegal operation on empty result set

我的其他返回空结果集的查询不会导致异常,所以我想我不应该捕获异常,但是有一个问题应该修复?

生成的MySQL工作正常(返回0行),因此问题不存在。

编辑2

问题出在groupBy()。如果应用issue中显示的更正,这似乎有效。

1 个答案:

答案 0 :(得分:7)

COUNT(*)的querydsl等效值为Wildcard.count