jooq 使用 oracle 文本包含查询

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


牛魔王的故事
浏览 66回答 1
1回答

梦里花落0921

您可能已经在查询的其他部分中使用了纯 SQL 模板化功能,可能是无意的。现在,您可以使用它来直接在 jOOQ 中构建供应商特定的语法扩展。例如:static Condition contains(Field<String> field, String search, int label) {&nbsp; &nbsp; return condition("contains({0}, {1}, {2}) > 0", field, val(search), inline(label));}在上面的例子中,我使用的是DSL.条件(字符串,对象...)
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java