Jooq 和 postgres:纯 sql 中的 pg_trgm 运算符产生错误“运算符不存在”

php小编苹果为您介绍一则java相关的问题:在使用jooq和postgresql时,可能会出现“运算符不存在”错误,原因是在纯sql中使用pg_trgm运算符不被识别。本文将详细解释这一问题的背景和解决方法。

问题内容

我正在使用的技术:java、spring boot、jooq、带有 pg_trgm 扩展的 postgres、r2dbc。

我尝试使用 pg_trgm 运算符在 postgres 上进行简单搜索,但 jooq 抛出错误。

代码示例:

string searchkeyword = "something";dsl.select(tables.example.id)          .from(tables.example)          .where(dsl.condition("{0} 

或者更简单:

dsl.resultquery("select 'a' 

产生错误 operator 不存在:字符变化

堆栈跟踪:

org.jooq.exception.dataaccessexception: sql [select 'a' 

请注意,如果直接在数据库上运行,以下纯 sql 查询将有效:

select id from example where 'something' 

另请注意:这不是类型转换问题。如果我将 searchkeyword 转换为文本,或者将其内联,则会产生类似的错误

另一个注意事项:如果我更改代码以使用 strict_word_similarity 函数而不是运算符,它就可以工作。问题仅出在运营商

解决方法

您可以将绑定变量显式转换为文本:

dsl.condition("{0}::text 

或者内联它而不是绑定它:

DSL.condition("{0} 

登录后复制

以上就是Jooq 和 postgres:纯 sql 中的 pg_trgm 运算符产生错误“运算符不存在”的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2621662.html

(0)
上一篇 2025年3月6日 23:36:37
下一篇 2025年3月3日 01:10:38

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论