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} <p>或者更简单:</p><pre class="brush:php;toolbar:false;">dsl.resultquery("select ‘a’ <p>产生错误 operator 不存在:字符变化 </p><p>堆栈跟踪:</p><pre class="brush:php;toolbar:false;">org.jooq.exception.dataaccessexception: sql [select ‘a’ <p>请注意,如果直接在数据库上运行,以下纯 sql 查询将有效:</p><pre class="brush:php;toolbar:false;">select id from example where ‘something’ <p>另请注意:这不是类型转换问题。如果我将 searchkeyword 转换为文本,或者将其内联,则会产生类似的错误</p><p>另一个注意事项:如果我更改代码以使用 strict_word_similarity 函数而不是运算符,它就可以工作。问题仅出在运营商</p><h2 class="daan">解决方法</h2><p>您可以将绑定变量显式转换为文本:</p><pre class="brush:java;toolbar:false;">dsl.condition("{0}::text <p>或者内联它而不是绑定它:</p><pre class="brush:java;toolbar:false;">DSL.condition("{0}
以上就是Jooq 和 postgres:纯 sql 中的 pg_trgm 运算符产生错误“运算符不存在”的详细内容,更多请关注范的资源库其它相关文章!
转载请注明:范的资源库 » Jooq和postgres:纯sql中的pg