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


Java VoltAbortException類代碼示例

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


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

示例1: loadTable

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
/**
 * Load a VoltTable directly into the EE at this partition.
 * <B>NOTE:</B> This should only be invoked by a system stored procedure.
 * @param txn_id
 * @param clusterName
 * @param databaseName
 * @param tableName
 * @param data
 * @param allowELT
 * @throws VoltAbortException
 */
public void loadTable(AbstractTransaction ts, String clusterName, String databaseName, String tableName, VoltTable data, int allowELT) throws VoltAbortException {
    Table table = this.catalogContext.database.getTables().getIgnoreCase(tableName);
    if (table == null) {
        throw new VoltAbortException("Table '" + tableName + "' does not exist in database " + clusterName + "." + databaseName);
    }
    if (data == null || data.getRowCount() == 0) {
        return;
    }
    
    if (debug.val)
        LOG.debug(String.format("Loading %d row(s) into %s [txnId=%d]",
                  data.getRowCount(), table.getName(), ts.getTransactionId()));
    ts.markExecutedWork(this.partitionId);
    this.ee.loadTable(table.getRelativeIndex(), data,
                      ts.getTransactionId(),
                      this.lastCommittedTxnId.longValue(),
                      ts.getLastUndoToken(this.partitionId),
                      allowELT != 0);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:31,代碼來源:PartitionExecutor.java

示例2: loadTable

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
@Override
public byte[] loadTable(long txnId, long spHandle, String clusterName, String databaseName,
        String tableName, VoltTable data,
        boolean returnUniqueViolations, boolean shouldDRStream, boolean undo) throws VoltAbortException
{
    Cluster cluster = m_context.cluster;
    if (cluster == null) {
        throw new VoltAbortException("cluster '" + clusterName + "' does not exist");
    }
    Database db = cluster.getDatabases().get(databaseName);
    if (db == null) {
        throw new VoltAbortException("database '" + databaseName + "' does not exist in cluster " + clusterName);
    }
    Table table = db.getTables().getIgnoreCase(tableName);
    if (table == null) {
        throw new VoltAbortException("table '" + tableName + "' does not exist in database " + clusterName + "." + databaseName);
    }

    return loadTable(txnId, spHandle, table.getRelativeIndex(), data, returnUniqueViolations, shouldDRStream, undo);
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:21,代碼來源:Site.java

示例3: voltLoadTable

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
public byte[] voltLoadTable(String clusterName, String databaseName,
                          String tableName, VoltTable data, boolean returnUniqueViolations, boolean shouldDRStream)
throws VoltAbortException
{
    if (data == null || data.getRowCount() == 0) {
        return null;
    }
    try {
        return m_site.loadTable(m_txnState.txnId, m_txnState.m_spHandle,
                         clusterName, databaseName,
                         tableName, data, returnUniqueViolations, shouldDRStream, false);
    }
    catch (EEException e) {
        throw new VoltAbortException("Failed to load table: " + tableName);
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:17,代碼來源:ProcedureRunner.java

示例4: run

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
public VoltTable[] run(long p, byte shouldRollback) {
    voltQueueSQL(truncate);
    voltQueueSQL(count);
    voltQueueSQL(scancount);
    VoltTable[] results = voltExecuteSQL(true);
    VoltTable data = results[1];
    VoltTableRow row = data.fetchRow(0);
    long optCount = row.getLong(0);
    if (optCount != 0) {
        throw new VoltAbortException("after truncate (opt) count not zero");
    }
    data = results[2];
    row = data.fetchRow(0);
    long scanCount = row.getLong(0);
    if (scanCount != 0) {
        throw new VoltAbortException("after truncate (scan) count not zero");
    }
    if (shouldRollback != 0) {
        throw new VoltAbortException("EXPECTED ROLLBACK");
    }
    return results;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:23,代碼來源:TRURTruncateTable.java

示例5: run

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
public VoltTable[] run(byte cid) {
    voltQueueSQL(d_getCount, cid);
    VoltTable[] results = voltExecuteSQL(false);
    VoltTable dim = results[0];
    long rowCount = dim.getRowCount();
    if (rowCount != 1) {
        throw new VoltAbortException(getClass().getName() +
                " invalid row count " + rowCount + " for count query" +
                " on dimension table for cid " + cid);
    }
    VoltTableRow row = dim.fetchRow(0);
    long c = row.getLong(0);
    switch ((int)c) {
    case 0:
        voltQueueSQL(d_Insert, cid, cid);
        results = voltExecuteSQL(true);
    case 1:
        return new VoltTable[] {};
    default:
        throw new VoltAbortException(getClass().getName() +
                " invalid count " + c + " of dimension rows" +
                " for cid " + cid);
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:25,代碼來源:PopulateDimension.java

示例6: loadTable

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
@Override
public byte[] loadTable(long txnId, long spHandle, String clusterName, String databaseName,
        String tableName, VoltTable data, boolean returnUniqueViolations, boolean shouldDRStream,
        boolean undo) throws VoltAbortException
{
    throw new RuntimeException("RO MP Site doesn't do this, shouldn't be here.");
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:8,代碼來源:MpRoSite.java

示例7: fail

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
static void fail(String procedureName, SQLStmt stmt, int batchIndex,
        String errMsg) throws VoltAbortException {

    String fullMsg = "Expectation failing in procedure: " + procedureName + "\n";
    fullMsg += "  Running SQL: " + stmt.getText() + "\n";
    fullMsg += "  Error message: " + errMsg;

    throw new VoltAbortException(fullMsg);
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:10,代碼來源:Expectation.java

示例8: loadTable

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
/**
 * loadTable method used by user-facing voltLoadTable() call in ProcedureRunner
 */
public byte[] loadTable(
        long txnId,
        long spHandle,
        String clusterName,
        String databaseName,
        String tableName,
        VoltTable data,
        boolean returnUniqueViolations,
        boolean shouldDRStream,
        boolean undo)
throws VoltAbortException;
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:15,代碼來源:SiteProcedureConnection.java

示例9: run

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
public VoltTable[] run(long p, byte shouldRollback) {
    voltQueueSQL(max);
    VoltTable[] results = voltExecuteSQL(true);
    if (results[0].getRowCount() != 1) {
        throw new VoltAbortException("rowcount for max is not one");
    }
    if (shouldRollback != 0) {
        throw new VoltAbortException("EXPECTED ROLLBACK");
    }
    return results;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:12,代碼來源:TRURScanAggTable.java

示例10: getCleanParams

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
private final ParameterSet getCleanParams(SQLStmt stmt, Object... inArgs) {
    final int numParamTypes = stmt.statementParamJavaTypes.length;
    final byte stmtParamTypes[] = stmt.statementParamJavaTypes;
    final Object[] args = new Object[numParamTypes];
    if (inArgs.length != numParamTypes) {
        throw new VoltAbortException(
                "Number of arguments provided was " + inArgs.length  +
                " where " + numParamTypes + " was expected for statement " + stmt.getText());
    }
    for (int ii = 0; ii < numParamTypes; ii++) {
        // this handles non-null values
        if (inArgs[ii] != null) {
            args[ii] = inArgs[ii];
            continue;
        }
        // this handles null values
        VoltType type = VoltType.get(stmtParamTypes[ii]);
        if (type == VoltType.TINYINT) {
            args[ii] = Byte.MIN_VALUE;
        } else if (type == VoltType.SMALLINT) {
            args[ii] = Short.MIN_VALUE;
        } else if (type == VoltType.INTEGER) {
            args[ii] = Integer.MIN_VALUE;
        } else if (type == VoltType.BIGINT) {
            args[ii] = Long.MIN_VALUE;
        } else if (type == VoltType.FLOAT) {
            args[ii] = VoltType.NULL_FLOAT;
        } else if (type == VoltType.TIMESTAMP) {
            args[ii] = new TimestampType(Long.MIN_VALUE);
        } else if (type == VoltType.STRING) {
            args[ii] = VoltType.NULL_STRING_OR_VARBINARY;
        } else if (type == VoltType.VARBINARY) {
            args[ii] = VoltType.NULL_STRING_OR_VARBINARY;
        } else if (type == VoltType.DECIMAL) {
            args[ii] = VoltType.NULL_DECIMAL;
        } else {
            throw new VoltAbortException("Unknown type " + type +
                    " can not be converted to NULL representation for arg " + ii +
                    " for SQL stmt: " + stmt.getText());
        }
    }

    return ParameterSet.fromArrayNoCopy(args);
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:45,代碼來源:ProcedureRunner.java

示例11: check

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
static void check(String procedureName, SQLStmt stmt, int batchIndex,
        Expectation expectation, VoltTable table) throws VoltAbortException {
    if (expectation == null)
        return;

    assert(table != null);
    int rowCount = table.getRowCount();

    switch (expectation.m_type) {
    case EXPECT_EMPTY:
        if (rowCount != 0) {
            fail(procedureName, stmt, batchIndex,
                 String.format("Expected zero row, but got %d", rowCount));
        }
        return;
    case EXPECT_ONE_ROW:
        if (rowCount != 1) {
            fail(procedureName, stmt, batchIndex,
                 String.format("Expected one row, but got %d", rowCount));
        }
        return;
    case EXPECT_ZERO_OR_ONE_ROW:
        if (rowCount > 1) {
            fail(procedureName, stmt, batchIndex,
                 String.format("Expected zero or one rows, but got %d", rowCount));
        }
        return;
    case EXPECT_NON_EMPTY:
        if (rowCount == 0) {
            fail(procedureName, stmt, batchIndex,
                 String.format("Expected one or more rows, but got %d", rowCount));
        }
        return;
    case EXPECT_SCALAR:
        if (checkScalar(table) == false) {
            fail(procedureName, stmt, batchIndex, "Expected scalar value");
        }
        return;
    case EXPECT_SCALAR_LONG:
        if (checkScalarLong(table) == false) {
            fail(procedureName, stmt, batchIndex, "Expected scalar long value");
        }
        return;
    case EXPECT_SCALAR_MATCH:
        if (checkScalarLong(table) == false) {
            fail(procedureName, stmt, batchIndex, "Expected scalar long value");
        }
        if (table.asScalarLong() != expectation.m_scalar) {
            fail(procedureName, stmt, batchIndex,
                    String.format("Expected scalar %d, but got %d", expectation.m_scalar, table.asScalarLong()));
        }
        return;
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:55,代碼來源:Expectation.java

示例12: runOne

import org.voltdb.VoltProcedure.VoltAbortException; //導入依賴的package包/類
void runOne() throws Exception {
    // 1/10th of txns roll back
    byte shouldRollback = (byte) (m_random.nextInt(10) == 0 ? 1 : 0);

    try {
        String procName = null;
        int expectedTables = 4;
        switch (m_type) {
        case PARTITIONED_SP:
            procName = "UpdatePartitionedSP";
            break;
        case PARTITIONED_MP:
            procName = "UpdatePartitionedMP";
            expectedTables = 5;
            break;
        case REPLICATED:
            procName = "UpdateReplicatedMP";
            expectedTables = 5;
            break;
        case HYBRID:
            procName = "UpdateBothMP";
            expectedTables = 5;
            break;
        case ADHOC_MP:
            procName = "UpdateReplicatedMPInProcAdHoc";
            expectedTables = 5;
            break;
        }

        byte[] payload = m_processor.generateForStore().getStoreValue();

        ClientResponse response;
        try {
            response = m_client.callProcedure(procName,
                    m_cid,
                    m_nextRid,
                    payload,
                    shouldRollback);
        } catch (Exception e) {
            if (shouldRollback == 0) {
                log.warn("ClientThread threw after " + m_txnsRun.get() +
                        " calls while calling procedure: " + procName +
                        " with args: cid: " + m_cid + ", nextRid: " + m_nextRid +
                        ", payload: " + payload +
                        ", shouldRollback: " + shouldRollback);
            }
            throw e;
        }

        // fake a proc call exception if we think one should be thrown
        if (response.getStatus() != ClientResponse.SUCCESS) {
            throw new UserProcCallException(response);
        }

        VoltTable[] results = response.getResults();

        m_txnsRun.incrementAndGet();

        if (results.length != expectedTables) {
            hardStop(String.format(
                    "Client cid %d procedure %s returned %d results instead of %d",
                    m_cid, procName, results.length, expectedTables), response);
        }
        VoltTable data = results[3];
        try {
            UpdateBaseProc.validateCIDData(data, "ClientThread:" + m_cid);
        }
        catch (VoltAbortException vae) {
            log.error("validateCIDData failed on: " + procName + ", shouldRollback: " +
                    shouldRollback + " data: " + data);
            throw vae;
        }
    }
    finally {
        // ensure rid is incremented (if not rolled back intentionally)
        if (shouldRollback == 0) {
            m_nextRid++;
        }
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:81,代碼來源:ClientThread.java


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