当前位置: 首页 > 知识库问答 >
问题:

jooq生成的针对postgres的查询的性能问题

厉熠彤
2023-03-14
return ctx.select(AT_TRAIL.POINT)
        .from(AT_TRAIL)
        .where(AT_TRAIL.ID.le(
                ctx.select(AT_TRAIL.ID)
                .from(
                        ctx.select(AT_TRAIL.ID, AT_TRAIL.POINT, field(
                                "point <-> ( " +
                                "  select point " +
                                "    from at_shelter  " +
                                "   where id = ( " +
                                "          select at_shelter " +
                                "            from at_last_shelter " +
                                "        ) "+
                                ")"
                        ).as("dist"))
                        .from(AT_TRAIL)
                        .orderBy(field("dist").asc())
                        .limit(1)
                )
        ))
        .orderBy(AT_TRAIL.ID.asc())
        .fetch()
        .map(r -> {
            PGpoint point = r.get(AT_TRAIL.POINT, PGpoint.class);
            return ImmutableMap.of("lat", point.x, "lng", point.y);
        });
return ctx.fetch(
        "  select point " +
        "    from at_trail " +
        "   where id <= ( " +
        "          select id " +
        "            from ( " +
        "                  select id, point, point <-> ( " +
        "                          select point " +
        "                            from at_shelter  " +
        "                           where id = ( " +
        "                                  select at_shelter " +
        "                                    from at_last_shelter " +
        "                                ) " +
        "                        ) as dist " +
        "                    from at_trail " +
        "                order by dist asc  " +
        "                   limit 1 " +
        "                ) t " +
        "        ) " +
        "order by id asc"
)
.map(r -> {
    PGpoint point = r.get(AT_TRAIL.POINT, PGpoint.class);
    return ImmutableMap.of("lat", point.x, "lng", point.y);
});

共有1个答案

广乐邦
2023-03-14

您的jOOQ查询是错误的(假设您的普通SQL查询是正确的)。考虑一下:

return ctx.select(AT_TRAIL.POINT)
        .from(AT_TRAIL)
        .where(AT_TRAIL.ID.le(
                ctx.select(AT_TRAIL.ID) // This is the outer query's ID, not the local ID
                .from(...)
        ))
        .orderBy(AT_TRAIL.ID.asc())
        .fetch()

你想写的是:

return ctx.select(AT_TRAIL.POINT)
        .from(AT_TRAIL)
        .where(AT_TRAIL.ID.le(
                ctx.select(field("id", AT_TRAIL.ID.getDataType())) // Better
                .from(...)
        ))
        .orderBy(AT_TRAIL.ID.asc())
        .fetch()

当然,现在您可以简化原来的查询,使其更加简单。例如。这似乎做了同样的事情:

select point 
from at_trail 
where id <= ( 
  select id
  from at_trail 
  order by point <-> ( 
    select point 
    from at_shelter  
    where id = ( 
      select at_shelter 
      from at_last_shelter 
    ) 
  ) asc  
  limit 1 
) 
order by id asc
ctx.select(AT_TRAIL.POINT)
   .from(AT_TRAIL)
   .where(AT_TRAIL.ID.le(
      select(AT_TRAIL.ID) // Now, no scoping problem anymore
     .from(AT_TRAIL)
     .orderBy(field("{0} <-> {1}", // jOOQ doesn't support this op, resorting to plain SQL
        AT_TRAIL.POINT,
        select(AT_SHELTER.POINT)
       .from(AT_SHELTER)
       .where(AT_SHELTER.ID.eq(
          select(AT_LAST_SHELTER.AT_SHELTER)
         .from(AT_LAST_SHELTER)
       ))
     ).asc())
     .limit(1)
   ))
   .orderBy(AT_TRAIL.ID.asc())
   .fetch();
 类似资料:
  • 我有一个名为TEST的表,列名为col1、col2、col3、col4。。。。。。。。。。所以,从信息模式来看。列我将获得有关此表对象的详细信息。 现在,我想通过从信息_模式中提供列名称,从测试表中构建一个select查询。柱。像这样,从information_schema中选择column_name。表_name='TEST'中的列。这会回来的 col1 col2 col3 我想在selectq

  • 我一直在使用Jooq生成的代码模式进行如下查询: 它与RecordMapperProvider一起根据表和模型类确定使用哪个RecordMapper: 这是我试图实现的一个例子: 新的查询包含了该组件,并且它正在改变传递给RecordMapperProvider的RecordType。这个新的RecordType不再与生成的代码匹配。 我的问题是:是否有一种解决方案,可以在查询中使用distinc

  • 我一直在理解Laravel查询生成器和纯SQL之间的融合。 我有2张桌子: user:包含具有主键的用户 User_Action:这是一个表,其中包含由和动作的组成的PRIMARYs记录。 ex: 使用者 用户操作 我的需要: 现在我想检索一个用户列表,其中包含每个用户的最新操作。因此,我只需要在从到的连接中获取一行,并且这一行必须是具有最新日期时间的一行。我的前任也是如此;我只想获取dateti

  • 问题内容: 每次执行此查询需要200毫秒以上的时间: 但这每次在第一次查询后每次执行只需要2-3毫秒: 注意在两个查询中相同的ID值。看起来第二个查询使用第一个查询的缓存结果。但是,为什么第一个查询不能使用缓存的结果本身?从第一个查询中删除不会更改任何内容。 当我使用其他ID执行第二个查询时,第一次执行该查询大约需要40毫秒,此后每次需要2-3毫秒。因此,第二个查询不仅运行速度更快,而且还缓存结果

  • 问题内容: 我在简单的数据库中有2个相似的模式-“ develop”和“ stage”。我已经使用Jooq为其中一种模式生成了Java类(例如“ develop”)。当jooq生成对db的查询时,它将隐式地将架构名称添加到所有查询的别名中 所以我的问题是,是否有办法在生成的查询中更改jooq模式名称(例如以“ stage”为例),而无需为“ stage”模式重新生成jooq的类呢? 问题答案: 您

  • 我正在为我的后端java项目使用PostgreSql和Jooq。Postgre字符集UTF-8排序规则WIN1254土耳其语。样本表 品牌表 < li>Id < li >名称 模型表 Id 名称 品牌ID “我”字是大“我”。它不是土耳其语字母中的“ı”。 Jooq以'brandi̇d'和“getBrand”的身份生成模型。不允许在html中使用“getBrand”。Spring给出了这种用法的错