我必须根据列值上的正则表达式从数据库中搜索记录。我正在使用 JPA 进行持久化,并且 JPA 中不支持 REGEXP,我用谷歌搜索并知道 EclipseLink 支持 REGEXP,我知道这是对可移植性的妥协,但我没有任何出路。
我想询问以下有关 EclipseLink REGEXP 支持的问题 -
- 如何使用 EclipseLink 支持的 REGEXP
- 在什么情况下保证对 REGEXP 的支持
- 如果不能保证失败的行为是什么
提前致谢
我必须根据列值上的正则表达式从数据库中搜索记录。我正在使用 JPA 进行持久化,并且 JPA 中不支持 REGEXP,我用谷歌搜索并知道 EclipseLink 支持 REGEXP,我知道这是对可移植性的妥协,但我没有任何出路。
我想询问以下有关 EclipseLink REGEXP 支持的问题 -
提前致谢
再会。您也可以使用 CriteriaBuilder api。这是您将搜索很长时间的解决方案:)
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery<?> query = cb.createQuery(...);
Root root = query.from(...);
List<Predicate> predicates = new ArrayList<Predicate>();
// https://www.eclipse.org/forums/index.php/t/831290/
if (cb instanceof org.eclipse.persistence.jpa.JpaCriteriaBuilder) {
org.eclipse.persistence.jpa.JpaCriteriaBuilder ecb = (org.eclipse.persistence.jpa.JpaCriteriaBuilder) cb;
org.eclipse.persistence.expressions.Expression exp = ecb.toExpression(root.get("field")).regexp("some regexp expression");
List<Expression<?>> parentExps = Collections.emptyList();
Predicate regExp = new org.eclipse.persistence.internal.jpa.querydef.PredicateImpl(entityManager.getMetamodel(), exp, parentExps, Predicate.BooleanOperator.AND);
predicates.add(regExp);
}
else { ... some other solution }
query.where(predicates.toArray(new Predicate[predicates.size()]));
表达式的 EclipseLink 文档可在此处找到:http: //www.eclipse.org/eclipselink/api/2.4/org/eclipse/persistence/expressions/Expression.html#regexp(java.lang.String)
您可以查看博客文章http://java-persistence-performance.blogspot.com/2012/05/jpql-vs-sql-have-both-with-eclipselink.html ,其中列出了一些支持 REGEXP 的数据库,但它归结为数据库。EclipseLink 将发出 SQL,由数据库来处理和控制行为。如果不能,它可能会抛出异常,说明 SQL 中存在错误。有关 REGEXP 如何工作的详细信息,您应该查看您的数据库文档。