簡體   English   中英

Querydsl:如何編寫“復雜”查詢

[英]Querydsl: How to write a “complex” query

我正在嘗試使用querydsl創建一個SQL語句。 我想要得到的是:

SELECT P.KEY, COUNT(P.VALUE)
 FROM RESOURCES R JOIN PROPERTIES P ON R.ID = P.ID
 WHERE P.KEY = "key" AND p.VALUE = "value"
 GROUP BY P.VALUE;

我嘗試編寫一些querydsl代碼:

String s = queryFactory
    .query()
    .from(QResource.resource)
    .join(QProperty.property)
    .where(QResource.resource.properties.any().key.eq("key").and(QResource.resource.properties.any().value.eq("value")))
    .groupBy(QProperty.property.value)
    .select(QProperty.property.key, QProperty.property.value.count())
    .toString();

我猜測它可以簡化,但另一方面我不太清楚它是否被很好地查詢。

有任何想法嗎?

一個更簡化的版本是:

QResource r = QResource.resource;
QProperty p = QProperty.property;
queryFactory
    .select(p.key, p.value.count())
    .from(r)
    .join(p).on(r.id.eq(p.id))
    .where(p.key.eq("key"), p.value.eq("value"))
    .groupBy(p.value)
    .fetchOne();

除了@natros答案外,布爾運算符可用於“和”邏輯

QResource r = QResource.resource;
QProperty p = QProperty.property;
queryFactory
    .select(p.key, p.value.count())
    .from(r)
    .join(p).on(r.id.eq(p.id))
    .where(p.key.eq("key").and(p.value.eq("value")))
    .groupBy(p.value)
    .fetchOne();

布爾生成器也可用於復雜邏輯

BooleanBuilder builder = new BooleanBuilder();
builder.and(p.key.eq("key"));
builder.and(p.value.eq("value"));
queryFactory
        .select(p.key, p.value.count())
        .from(r)
        .join(p).on(r.id.eq(p.id))
        .where(builder)
        .groupBy(p.value)
        .fetchOne();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM