我正在使用 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 回答
![?](http://img1.sycdn.imooc.com/545863dc00011d2202200220-100-100.jpg)
梦里花落0921
TA贡献1772条经验 获得超6个赞
您可能已经在查询的其他部分中使用了纯 SQL 模板化功能,可能是无意的。现在,您可以使用它来直接在 jOOQ 中构建供应商特定的语法扩展。例如:
static Condition contains(Field<String> field, String search, int label) {
return condition("contains({0}, {1}, {2}) > 0", field, val(search), inline(label));
}
在上面的例子中,我使用的是DSL.条件(字符串,对象...)
添加回答
举报
0/150
提交
取消