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


Java RolapUtil類代碼示例

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


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

示例1: removeEldestEntry

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
protected boolean removeEldestEntry(
    Map.Entry<Integer, MutableConnectionInfo> e)
{
    if (size() > maxSize) {
        if (RolapUtil.MONITOR_LOGGER.isTraceEnabled()) {
            RolapUtil.MONITOR_LOGGER.trace(
                "ConnectionInfo("
                + e.getKey()
                + ") evicted. Stack is:"
                + Util.nl
                + e.getValue().stack);
        }
        return true;
    }
    return false;
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:17,代碼來源:MonitorImpl.java

示例2: visit

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public Object visit(ConnectionStartEvent event) {
    final MutableConnectionInfo conn =
        new MutableConnectionInfo(event.stack);
    connectionMap.put(event.connectionId, conn);
    foo(conn, event);
    foo(server.aggConn, event);
    if (RolapUtil.MONITOR_LOGGER.isTraceEnabled()) {
        RolapUtil.MONITOR_LOGGER.trace(
            "Connection("
            + event.connectionId
            + ") created. stack is:"
            + Util.nl
            + event.stack);
    }
    return null;
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:17,代碼來源:MonitorImpl.java

示例3: Event

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
/**
 * Creates an Event.
 *
 * @param timestamp Timestamp
 *
 */
public Event(
    long timestamp)
{
    this.timestamp = timestamp;
    if (RolapUtil.MONITOR_LOGGER.isTraceEnabled()) {
        try {
            throw new Exception();
        } catch (Exception e) {
            StringWriter sw = new StringWriter();
            e.printStackTrace(new PrintWriter(sw, true));
            this.stack = sw.toString();
        }
    } else {
        this.stack = null;
    }
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:23,代碼來源:Event.java

示例4: 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

示例5: getTableCardinality

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public int getTableCardinality(
    Dialect dialect,
    DataSource dataSource,
    String catalog,
    String schema,
    String table,
    Execution execution)
{
    StringBuilder buf = new StringBuilder("select count(*) from ");
    dialect.quoteIdentifier(buf, catalog, schema, table);
    final String sql = buf.toString();
    SqlStatement stmt =
        RolapUtil.executeQuery(
            dataSource,
            sql,
            new Locus(
                execution,
                "SqlStatisticsProvider.getTableCardinality",
                "Reading row count from table "
                + Arrays.asList(catalog, schema, table)));
    try {
        ResultSet resultSet = stmt.getResultSet();
        if (resultSet.next()) {
            ++stmt.rowCount;
            return resultSet.getInt(1);
        }
        return -1; // huh?
    } catch (SQLException e) {
        throw stmt.handle(e);
    } finally {
        stmt.close();
    }
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:34,代碼來源:SqlStatisticsProvider.java

示例6: getQueryCardinality

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public int getQueryCardinality(
    Dialect dialect,
    DataSource dataSource,
    String sql,
    Execution execution)
{
    final StringBuilder buf = new StringBuilder();
    buf.append(
        "select count(*) from (").append(sql).append(")");
    if (dialect.requiresAliasForFromQuery()) {
        if (dialect.allowsAs()) {
            buf.append(" as ");
        } else {
            buf.append(" ");
        }
        dialect.quoteIdentifier(buf, "init");
    }
    final String countSql = buf.toString();
    SqlStatement stmt =
        RolapUtil.executeQuery(
            dataSource,
            countSql,
            new Locus(
                execution,
                "SqlStatisticsProvider.getQueryCardinality",
                "Reading row count from query [" + sql + "]"));
    try {
        ResultSet resultSet = stmt.getResultSet();
        if (resultSet.next()) {
            ++stmt.rowCount;
            return resultSet.getInt(1);
        }
        return -1; // huh?
    } catch (SQLException e) {
        throw stmt.handle(e);
    } finally {
        stmt.close();
    }
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:40,代碼來源:SqlStatisticsProvider.java

示例7: getColumnCardinality

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public int getColumnCardinality(
    Dialect dialect,
    DataSource dataSource,
    String catalog,
    String schema,
    String table,
    String column,
    Execution execution)
{
    final String sql =
        generateColumnCardinalitySql(
            dialect, schema, table, column);
    if (sql == null) {
        return -1;
    }
    SqlStatement stmt =
        RolapUtil.executeQuery(
            dataSource,
            sql,
            new Locus(
                execution,
                "SqlStatisticsProvider.getColumnCardinality",
                "Reading cardinality for column "
                + Arrays.asList(catalog, schema, table, column)));
    try {
        ResultSet resultSet = stmt.getResultSet();
        if (resultSet.next()) {
            ++stmt.rowCount;
            return resultSet.getInt(1);
        }
        return -1; // huh?
    } catch (SQLException e) {
        throw stmt.handle(e);
    } finally {
        stmt.close();
    }
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:38,代碼來源:SqlStatisticsProvider.java

示例8: 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

示例9: 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

示例10: run

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public void run() {
    try {
        for (;;) {
            try {
                final Pair<Handler, Message> entry = eventQueue.take();
                final Handler handler = entry.left;
                final Message message = entry.right;
                final Object result = message.accept(handler);
                if (message instanceof Command) {
                    responseMap.put((Command) message, result);
                } else {
                    // Broadcast the event to anyone who is interested.
                    RolapUtil.MONITOR_LOGGER.debug(message);
                }
                if (message instanceof ShutdownCommand) {
                    LOGGER.debug(
                        "ShutdownCommand received. Monitor thread is shutting down.");
                    return;
                }
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt();
                LOGGER.warn(
                    "Monitor thread interrupted.",
                    e);
                return;
            } catch (Throwable t) {
                LOGGER.error(
                    "Runtime error on the monitor thread.",
                    t);
            }
        }
    } finally {
        running = false;
    }
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:36,代碼來源:MonitorImpl.java

示例11: binarySearch

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public <T extends Comparable<T>> int binarySearch(
    T[] ts, int start, int end, T t)
{
    return Arrays.binarySearch(
        ts, start, end, t,
        RolapUtil.ROLAP_COMPARATOR);
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:8,代碼來源:UtilCompatibleJdk16.java

示例12: binarySearch

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public <T extends Comparable<T>> int binarySearch(
    T[] ts, int start, int end, T t)
{
    final int i = Collections.binarySearch(
        Arrays.asList(ts).subList(start, end), t,
        RolapUtil.ROLAP_COMPARATOR);
    return (i < 0) ? (i - start) : (i + start);
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:9,代碼來源:UtilCompatibleJdk15.java

示例13: testRolapUtilComparator

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public void testRolapUtilComparator() throws Exception {
    final Comparable[] compArray =
        new Comparable[] {
            "1",
            "2",
            "3",
            "4"
    };
    // Will throw a ClassCastException if it fails.
    Util.binarySearch(
        compArray, 0, compArray.length,
        RolapUtil.sqlNullValue);
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:14,代碼來源:UtilTestCase.java

示例14: initialize

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
public void initialize() throws Exception {
    if (this.initialize) {
        return;
    }

    check();
    if (this.connection == null) {
        RolapUtil.loadDrivers(this.jdbcDriver);

        if (this.userName == null) {
            this.connection = DriverManager.getConnection(this.jdbcURL);
        } else {
            this.connection = DriverManager.getConnection(
                this.jdbcURL, this.userName, this.password);
        }
    }

    final DatabaseMetaData metaData = this.connection.getMetaData();

    String productName = metaData.getDatabaseProductName();
    String version = metaData.getDatabaseProductVersion();
    LOGGER.info("Output connection is " + productName + ", " + version);

    if (!metaData.supportsBatchUpdates()) {
        this.batchSize = 1;
    }
    this.dialect = DialectManager.createDialect(null, this.connection);
    this.initialize = true;
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:30,代碼來源:DBLoader.java

示例15: executeAndCancelAtSqlFetch

import mondrian.rolap.RolapUtil; //導入依賴的package包/類
private Long executeAndCancelAtSqlFetch(
    final String query, final String triggerSql, final String component)
    throws Exception
{
    // avoid cache to ensure sql executes
    TestContext context = getTestContext().withFreshConnection();
    context.flushSchemaCache();

    RolapConnection conn =  (RolapConnection) context.getConnection();
    final mondrian.server.Statement stmt = conn.getInternalStatement();
    // use the logger to block and trigger cancelation at the right time
    Logger sqlLog = RolapUtil.SQL_LOGGER;
    propSaver.set(sqlLog, org.apache.log4j.Level.DEBUG);
    final Execution exec = new Execution(stmt, 50000);
    final CountDownLatch okToGo = new CountDownLatch(1);
    SqlCancelingAppender canceler =
        new SqlCancelingAppender(component, triggerSql, exec, okToGo);
    stmt.setQuery(conn.parseQuery(query));
    sqlLog.addAppender(canceler);
    try {
        conn.execute(exec);
        Assert.fail("Query not canceled.");
    } catch (QueryCanceledException e) {
        // 5 sec just in case it all goes wrong
        if (!okToGo.await(5, TimeUnit.SECONDS)) {
            Assert.fail("Timeout reading sql statement end from log.");
        }
        return canceler.rows;
    } finally {
        sqlLog.removeAppender(canceler);
        context.close();
    }
    return null;
}
 
開發者ID:OSBI,項目名稱:mondrian,代碼行數:35,代碼來源:BasicQueryTest.java


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