Hibernate 条件接受 %% 值
Hibernate criteria accepting %% value
我正在使用下面的 Hibernate 代码来过滤 workFlowName
。
crt.add(Restrictions.like("workFlowName", workFlow, MatchMode.ANYWHERE));
// crt is the criteria
问题是当我将值从网络 (TextBox) 传递给 workFlow 时。它正确地获取了值(我正在传递 sym
在文本框中,如果获取 10 records.if 我再次传递相同的值,如 %sym%
它正在获取相同的记录)。
条件是否将%%
作为参数时省略?
Hibernate 不会转义 like 中的特殊字符(例如百分比 %
符号)。但是有说明如何解决(escape it):
- Escaping special characters in Hibernate queries
- Using hibernate criteria, is there a way to escape special characters?
- Escape special characters in hibernate criteria
通常我们可以实现自己的EscapedILikeExpression
(取自上面第一个link)
class EscapedILikeExpression extends IlikeExpression {
private static final String HIBERNATE_ESCAPE_CHAR = "\";
public EscapedILikeExpression(String propertyName, Object value) {
super(propertyName, value);
}
public EscapedILikeExpression(String propertyName, String value, MatchMode matchMode) {
super(propertyName, replaceAll(value), matchMode);
}
private static String replaceAll(String value) {
return value
.replace("\", HIBERNATE_ESCAPE_CHAR + "\")
.replace("_", HIBERNATE_ESCAPE_CHAR + "_")
.replace("%", HIBERNATE_ESCAPE_CHAR + "%");
}
}
和
public class EscapedRestrictions {
public static Criterion ilike(String propertyName, String value) {
return new EscapedILikeExpression(propertyName, value);
}
public static Criterion ilike(String propertyName, String value, MatchMode matchMode) {
return new EscapedILikeExpression(propertyName, value, matchMode);
}
}
现在我们应该可以调用
crt.add(EscapedRestrictions.ilike("workFlowName", workFlow, MatchMode.ANYWHERE));
我正在使用下面的 Hibernate 代码来过滤 workFlowName
。
crt.add(Restrictions.like("workFlowName", workFlow, MatchMode.ANYWHERE));
// crt is the criteria
问题是当我将值从网络 (TextBox) 传递给 workFlow 时。它正确地获取了值(我正在传递 sym
在文本框中,如果获取 10 records.if 我再次传递相同的值,如 %sym%
它正在获取相同的记录)。
条件是否将%%
作为参数时省略?
Hibernate 不会转义 like 中的特殊字符(例如百分比 %
符号)。但是有说明如何解决(escape it):
- Escaping special characters in Hibernate queries
- Using hibernate criteria, is there a way to escape special characters?
- Escape special characters in hibernate criteria
通常我们可以实现自己的EscapedILikeExpression
(取自上面第一个link)
class EscapedILikeExpression extends IlikeExpression {
private static final String HIBERNATE_ESCAPE_CHAR = "\";
public EscapedILikeExpression(String propertyName, Object value) {
super(propertyName, value);
}
public EscapedILikeExpression(String propertyName, String value, MatchMode matchMode) {
super(propertyName, replaceAll(value), matchMode);
}
private static String replaceAll(String value) {
return value
.replace("\", HIBERNATE_ESCAPE_CHAR + "\")
.replace("_", HIBERNATE_ESCAPE_CHAR + "_")
.replace("%", HIBERNATE_ESCAPE_CHAR + "%");
}
}
和
public class EscapedRestrictions {
public static Criterion ilike(String propertyName, String value) {
return new EscapedILikeExpression(propertyName, value);
}
public static Criterion ilike(String propertyName, String value, MatchMode matchMode) {
return new EscapedILikeExpression(propertyName, value, matchMode);
}
}
现在我们应该可以调用
crt.add(EscapedRestrictions.ilike("workFlowName", workFlow, MatchMode.ANYWHERE));