gpt4 book ai didi

java - jooq使用oracle文本包含查询

转载 作者:行者123 更新时间:2023-11-30 05:41:19 32 4
gpt4 key购买 nike

我正在使用 jooq 构建查询,并且需要使用 Oracle 文本向 where 子句添加条件。到目前为止,我已经建立了一组条件,并使用它们在最后构建查询......

List<Condition> conditions = new ArrayList<Condition>();
if(null != searchCriteria.getId()) {
conditions.add(field("id").eq(searchCriteria.getId()));
} else if(null != searchCriteria.getSurname()) {
//add contains condition here. e.g. "CONTAINS (SURNAME, 'POTTER', 1) > 0
}

我不知道如何构建这个条件,或者至少手动构建这个 SQL 字符串,然后添加作为条件,然后生成完整的查询,例如...

org.jooq.Query ps = select(field("ID")).from(table("PERSON per").where(conditions);

最佳答案

您已经使用过plain SQL templating可能是无意中在查询的其他部分中出现的。现在您可以使用它直接在 jOOQ 中构建供应商特定的语法扩展。例如:

static Condition contains(Field<String> field, String search, int label) {
return condition("contains({0}, {1}, {2}) > 0", field, val(search), inline(label));
}

在上面的示例中,我使用 DSL.condition(String, Object...)

关于java - jooq使用oracle文本包含查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55578377/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com