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