DetachedCriteria isNotEmpty for Oracle



我今天发现了以下问题。

因为我使用分离的条件,例如detachedCriteria.add(Restrictions.ne(field, value));来检查字符串是否为空。我发现这对甲骨文不起作用。

由于"不为空"-检查对我来说还不够,我试图复制

WHERE length(trim(COL_NAME)) > 0

在甲骨文上工作的模式,例如:

detachedCriteria.add(Restrictions.sqlRestriction(String.format("length(trim({%s}.%s)) > 0", aliasName, field)));

现在我在那之后得到了以下标准(调试检查(:

length(trim({testtable}.name.de)) > 0

其中 testtable 是表名,name@Embedded 类,属性 de@Embedabble的属性。

它最终导致一个 NullPointerExcpetion....

Method threw 'java.lang.NullPointerException' exception.
0 = {StackTraceElement@32701} "oracle.jdbc.driver.T4C8Oall.getNumRows(T4C8Oall.java:879)"
1 = {StackTraceElement@32702} "oracle.jdbc.driver.T4CPreparedStatement.executeForDescribe(T4CPreparedStatement.java:881)"
2 = {StackTraceElement@32703} "oracle.jdbc.driver.OracleStatement.executeMaybeDescribe(OracleStatement.java:1145)"
3 = {StackTraceElement@32704} "oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1267)"
4 = {StackTraceElement@32705} "oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3449)"
5 = {StackTraceElement@32706} "oracle.jdbc.driver.OraclePreparedStatement.executeQuery(OraclePreparedStatement.java:3493)"
6 = {StackTraceElement@32707} "oracle.jdbc.driver.OraclePreparedStatementWrapper.executeQuery(OraclePreparedStatementWrapper.java:1491)"
7 = {StackTraceElement@32708} "com.jolbox.bonecp.PreparedStatementHandle.executeQuery(PreparedStatementHandle.java:174)"
8 = {StackTraceElement@32709} "org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.extract(ResultSetReturnImpl.java:82)"
9 = {StackTraceElement@32710} "org.hibernate.loader.Loader.getResultSet(Loader.java:2065)"...

没有任何消息。谁能解释我做错了什么?

休眠:4.3.6.最终版

根据文档,我自己找到了答案:

sql限制
公共静态条件 sql限制(字符串 sql(

应用以 SQL 表示的约束。任何出现的 {别名} 都将 替换为表别名。

参数:
.sql-
返回:
标准

我的代码应该看起来像这样:

/**
 * Adds a constraint to the where clause checking if the specified field value's length is bigger than ZERO
 * @param sqlField the field of the table the query belongs to (in SQL Syntax not hql or something else)
 * @return Query
 */
public final Query<T> isNotEmptySQLField(String sqlField){
    //Apply a constraint expressed in SQL. Any occurrences of {alias} will be replaced by the table alias.
    detachedCriteria.add(
          Restrictions.sqlRestriction(
              String.format("length(trim({alias}.%s)) > 0", sqlField)));
    return this;
}

其中sqlFieldDATABASE中列的NAME

最新更新