如何使用Hibernate和MySQL在Spring中使用Querydsl执行按位操作

时间:2016-08-06 00:24:37

标签: mysql spring hibernate querydsl

我在mysql表中有一个int列,我用它来存储与状态相关的位。我感兴趣的是根据状态字段中是否设置了一个或多个位来查询。

我尝试了以下内容:Expressions.booleanTemplate("(status & {0}) = 0", A_BIT_MASK); 但是,这给了我一个InvalidDataAccessApiUsageException: org.hibernate.QueryException: unexpected char: '&'

我正在使用Spring Data with Hibernate和MySQL。我试图使用Querydsl查询数据库。

1 个答案:

答案 0 :(得分:0)

首先你需要在hibernate中创建按位

public class MySQLDialect extends org.hibernate.dialect.MySQLDialect {

    public MySQLDialect() {
        super();
        registerFunction("bitand", new SQLFunctionTemplate(IntegerType.INSTANCE, "(?1 & ?2)"));
    }
}

然后你可以在querydsl或hibernate

中引用它
NumberTemplate<Integer> numberTemplate = Expressions.numberTemplate(Integer.class, "function('bitand', {0}, {1})", path, value);