链接生成的Jooq类时如何解决模糊匹配

问题描述 投票:1回答:1

我已经在JPA中定义了我的模型,并且正在为我的应用程序编写一些查询。我正在使用JOOQ生成的类将所有表连接在一起,以检查所请求的资源是否实际属于请求用户。

但是,当我这样做时,我收到以下警告:

Ambiguous match found for ID. Both "alias_4548634"."ID" and "alias_47496750"."ID" match.

java.sql.SQLWarning: null                                                                                                                                       
        at org.jooq.impl.Fields.field(Fields.java:132) ~[jooq-3.11.10.jar:?]
... etc

这是我的代码

db.select(countField)
  .from(thing)
  .where(JThing.THING.thingBucket().bucket().organization().customer().ID.in(idList))
  .orderBy(countField)

这是它生成的SQL

SELECT 
  count(PUBLIC.THING.ID) AS count
FROM (
  PUBLIC.THING
    LEFT OUTER JOIN (
      PUBLIC.THING_BUCKET AS alias_72652126
        LEFT OUTER JOIN (
          PUBLIC.BUCKET AS alias_4548634
            LEFT OUTER JOIN (
              PUBLIC.ORGANISATION AS alias_43016761
                LEFT OUTER JOIN PUBLIC.CUSTOMER AS alias_47496750
                ON alias_43016761.CUSTOMER_ID = alias_47496750.ID
            )
            ON alias_4548634.ORGANISATION_ID = alias_43016761.ID
        )
        ON alias_72652126.ID = alias_4548634.ID
    )
    ON PUBLIC.THING.THING_BUCKET_ID = alias_72652126.ID
  )
WHERE alias_47496750.ID IN (81353)
ORDER BY count

鉴于JOOQ正在生成SQL,我希望它能够在不抛出错误的情况下理解它。我错过了什么?如何配置/查询/解决SQLWarning的问题?

UPDATE

在玩完之后我发现了问题的根源。

THING_BUCKET是BUCKET的子类型,因此THING_BUCKET.ID = BUCKET.ID

如果我重写查询,我得到相同的结果,但没有错误

SELECT 
  count(PUBLIC.THING.ID) AS count
FROM (
  PUBLIC.THING
        LEFT OUTER JOIN (
          PUBLIC.BUCKET AS alias_4548634
            LEFT OUTER JOIN (
              PUBLIC.ORGANISATION AS alias_43016761
                LEFT OUTER JOIN PUBLIC.CUSTOMER AS alias_47496750
                ON alias_43016761.CUSTOMER_ID = alias_47496750.ID
            )
            ON alias_4548634.ORGANISATION_ID = alias_43016761.ID
        )
    ON PUBLIC.THING.BUCKET_ID = alias_4548634.ID
  )
WHERE alias_47496750.ID IN (81353)
ORDER BY count

所以我想要做的就是去

db.select(countField)
  .from(thing)
  .where(JThing.THING.bucket().organization().customer().ID.in(idList))
  .orderBy(countField)

并将我的THING直接加入BUCKET而不是THING_BUCKET,但我不知道如何使用生成的类完成此操作。

java sql postgresql jooq
1个回答
0
投票

根据您的描述,看起来像BUCKET和THINK_BUCKET在数据库级别被描述为子类型,正被jooq生成的类弄糊涂了。

短期修复可能是,为了削减数据库级别中的层次关系,重新生成并查看会发生什么。

© www.soinside.com 2019 - 2024. All rights reserved.