當前位置: 首頁>>代碼示例>>Java>>正文


Java RolapUtil.sqlNullValue方法代碼示例

本文整理匯總了Java中mondrian.rolap.RolapUtil.sqlNullValue方法的典型用法代碼示例。如果您正苦於以下問題:Java RolapUtil.sqlNullValue方法的具體用法?Java RolapUtil.sqlNullValue怎麽用?Java RolapUtil.sqlNullValue使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在mondrian.rolap.RolapUtil的用法示例。


在下文中一共展示了RolapUtil.sqlNullValue方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: checkInList

import mondrian.rolap.RolapUtil; //導入方法依賴的package包/類
public BitKey checkInList(BitKey inListLHSBitKey) {
    // ValueColumn predicate by itself is not using IN list; when it is
    // one of the children to an OR predicate, then using IN list
    // is helpful. The later is checked by passing in a bitmap that
    // represent the LHS or the IN list, i.e. the column that is
    // constrained by the OR.
    BitKey inListRHSBitKey = inListLHSBitKey.copy();

    if (!getConstrainedColumnBitKey().equals(inListLHSBitKey)
        || value == RolapUtil.sqlNullValue)
    {
        inListRHSBitKey.clear();
    }

    return inListRHSBitKey;
}
 
開發者ID:Twixer,項目名稱:mondrian-3.1.5,代碼行數:17,代碼來源:ValueColumnPredicate.java

示例2: toArray

import mondrian.rolap.RolapUtil; //導入方法依賴的package包/類
private static Comparable[] toArray(
    SortedSet<Comparable> keySet,
    boolean hasNull)
{
    int size = keySet.size();
    if (hasNull) {
        size++;
    }
    Comparable[] keys = keySet.toArray(new Comparable[size]);
    if (hasNull) {
        keys[size - 1] = RolapUtil.sqlNullValue;
    }
    return keys;
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:15,代碼來源:SegmentAxis.java

示例3: getValuesAndIndicator

import mondrian.rolap.RolapUtil; //導入方法依賴的package包/類
@SuppressWarnings({"unchecked"})
public Pair<SortedSet<Comparable>, Boolean> getValuesAndIndicator() {
    if (keys.length > 0
        && keys[keys.length - 1] == RolapUtil.sqlNullValue)
    {
        return (Pair) Pair.of(
            new ArraySortedSet(keys, 0, keys.length - 1),
            Boolean.TRUE);
    } else {
        return (Pair) Pair.of(
            new ArraySortedSet(keys),
            Boolean.FALSE);
    }
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:15,代碼來源:SegmentAxis.java

示例4: toSql

import mondrian.rolap.RolapUtil; //導入方法依賴的package包/類
public void toSql(SqlQuery sqlQuery, StringBuilder buf) {
    final RolapStar.Column column = getConstrainedColumn();
    String expr = column.generateExprString(sqlQuery);
    buf.append(expr);
    Object key = getValue();
    if (key == RolapUtil.sqlNullValue) {
        buf.append(" is null");
    } else {
        buf.append(" = ");
        sqlQuery.getDialect().quote(buf, key, column.getDatatype());
    }
}
 
開發者ID:Twixer,項目名稱:mondrian-3.1.5,代碼行數:13,代碼來源:ValueColumnPredicate.java

示例5: checkInList

import mondrian.rolap.RolapUtil; //導入方法依賴的package包/類
public BitKey checkInList(SqlQuery sqlQuery, BitKey inListLHSBitKey) {
    // AND predicate by itself is not using IN list; when it is
    // one of the children to an OR predicate, then using IN list
    // is helpful. The later is checked by passing in a bitmap that
    // represent the LHS or the IN list, i.e. the columns that are
    // constrained by the OR.

    // If the child predicates contains null values, those predicates cannot
    // be translated as IN list; however, the rest of the child predicates
    // might still be translated to IN.  For example, neither of the two AND
    // conditions below(part of an OR list) can be translated using IN list,
    // covering all the levels
    //
    //  (null, null, San Francisco)
    //  (null, null, New York)
    //
    // However, after extracting the null part, they can be translated to:
    //
    // (country is null AND state is null AND city IN ("San Fancisco", "New
    // York"))
    //
    // which is still more compact than the default AND/OR translation:
    //
    // (country is null AND state is null AND city = "San Francisco") OR
    // (country is null AND state is null AND city = "New York")
    //
    // This method will mark all the columns that can be translated as part
    // of IN list, so that similar predicates can be grouped together to
    // form partial IN list sql. By default, all columns constrained by this
    // predicates can be part of an IN list.
    //
    // This is very similar to the logic in
    // SqlConstraintUtil.generateMultiValueInExpr().  The only difference
    // being that the predicates here are all "flattened" so the hierarchy
    // information is no longer available to guide the grouping of
    // predicates with common parents. So some optimization possible in
    // generateMultiValueInExpr() is not tried here, as they require
    // implementing "longest common prefix" algorithm which is an overkill.
    BitKey inListRHSBitKey = inListLHSBitKey.copy();

    if (!columnBitKey.equals(inListLHSBitKey)
        || (children.size() > 1
         && !sqlQuery.getDialect().supportsMultiValueInExpr()))
    {
        inListRHSBitKey.clear();
    } else {
        for (StarPredicate predicate : children) {
            // If any predicate requires comparison to null value, cannot
            // use IN list for this predicate.
            if (predicate instanceof ValueColumnPredicate) {
                ValueColumnPredicate columnPred =
                    ((ValueColumnPredicate) predicate);
                if (columnPred.getValue() == RolapUtil.sqlNullValue) {
                    // This column predicate cannot be translated to IN
                    inListRHSBitKey.clear(
                        columnPred.getConstrainedColumn().getBitPosition());
                }
                // else do nothing because this column predicate can be
                // translated to IN
            } else {
                inListRHSBitKey.clear();
                break;
            }
        }
    }
    return inListRHSBitKey;
}
 
開發者ID:Twixer,項目名稱:mondrian-3.1.5,代碼行數:68,代碼來源:AndPredicate.java


注:本文中的mondrian.rolap.RolapUtil.sqlNullValue方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。