一尘不染

Hibernate Regexp MySQL

mysql

我问这个问题以展示MySQL和Hibernate如何通过正则表达式相互配合。

问题:

SELECT * FROM table WHERE regexp column '\d'

解:

转到我的答案。

希望这可以帮助。


阅读 502

收藏
2020-05-17

共1个答案

一尘不染

基本上,要在Hibernate中使用MySQL regexp函数,我们需要创建一个“ SQLFunctionTemplate”。

现在,如何做:

首先:创建一个名为“ AppMySQLDialect”的类,并从MySQLDialect扩展,然后覆盖空的构造函数,最后注册regexp函数:

public class AppMySQLDialect extends MySQLDialect {
    public AppMySQLDialect() {
        super();
        /**
         * Function to evaluate regexp in MySQL
         */
        registerFunction("regexp", new SQLFunctionTemplate(Hibernate.INTEGER, "?1 REGEXP ?2"));
    }
}

好的,现在让我们按以下方式使用它:

FROM Entity E WHERE regexp(E.string2evaluate, '\d') = 1

创建您的HibernateQuery并执行。

2020-05-17