jooq使用oracle文本包含查询

时间:2019-04-08 17:04:35

标签: java jooq

我正在使用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);

1 个答案:

答案 0 :(得分:1)

您可能已无意中在查询的其他部分中使用了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...)