程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

在 jOOQ 的 SQL 查询中结合纯 SQL 和 DSL

发布于2023-06-07 20:02     阅读(1175)     评论(0)     点赞(23)     收藏(0)


我有一个复杂的纯 SQL 查询(带有子选择、多重连接、数据库特定函数)但我想使用 jOOQ 的 DSL 来生成例如 order by 子句。

我想要实现的是:

DSL
    .using(datasource)
    .select("select column from table")
    .orderBy(DSL.fieldByName("column"))

哪个 jOOQ 可以转变为:

select * (select column from table) q order by q.column;

这可以做到吗?


解决方案


你很接近。以下是可能的:

DSL.using(datasource, dialect)
   .select()
   .from("(select column from table) t")
   .orderBy(DSL.field("t.column"));

您必须自己明确地包装(并且根据 SQL 方言,还重命名)您的派生表。

请注意,我使用的DSL.field()是 ,而不是DSL.fieldByName(),因为后者会生成区分大小写的column引用。然后,您的纯 SQL 查询还必须生成区分大小写的column引用。



所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.javaheidong.com/blog/article/674309/20113e75355d6c4c732a/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

23 0
收藏该文
已收藏

评论内容:(最多支持255个字符)