java - 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);
解决方案
您已经在查询的其他部分中使用了纯 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.condition(String, Object...)
推荐阅读
- javascript - 通过 PHP Form 中的 Multiply select 和 Switcher 将表单数据插入 SQL 表的快捷方式?
- php - php DateTime() 在过去分配日期时返回当前日期
- jquery - jQuery - 如果选中复选框(多个条件),则删除活动类
- .net-core - .NET Core 错误 1053 服务没有及时响应启动或控制请求
- r - 用一个共享图例排列 ggsurv 图
- opencv - 如何从相机坐标系获取电视屏幕上的真实世界投影坐标
- c# - 为 Backgroundjob 记录通用接口
- c++ - 以跨平台方式将图像源路径从 C++ 发送到 QML
- docker - Cron 作业杀死所有悬挂的 docker 容器
- view - 我可以在 h2 SCRPT 命令中影响转储/导出顺序吗