我在mysql表中有一个int列,我用它来存储与状态相关的位。我感兴趣的是根据状态字段中是否设置了一个或多个位来查询。
我尝试了以下内容:Expressions.booleanTemplate("(status & {0}) = 0", A_BIT_MASK);
但是,这给了我一个InvalidDataAccessApiUsageException: org.hibernate.QueryException: unexpected char: '&'
。
我正在使用Spring Data with Hibernate和MySQL。我试图使用Querydsl查询数据库。
答案 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);