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


Java VoltTableRow.get方法代碼示例

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


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

示例1: compare

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
@Override
public int compare(Object arg0, Object arg1) {
    VoltTableRow r1 = (VoltTableRow)arg0;
    VoltTableRow r2 = (VoltTableRow)arg1;

    String r1d1 = (String) r1.get(0, VoltType.STRING);
    String r1d2 = (String) r1.get(1, VoltType.STRING);
    String r2d1 = (String) r2.get(0, VoltType.STRING);
    String r2d2 = (String) r2.get(1, VoltType.STRING);

    int r1d1_pos = Integer.valueOf(r1d1.substring(3));
    int r1d2_pos = Integer.valueOf(r1d2.substring(3));
    int r2d1_pos = Integer.valueOf(r2d1.substring(3));
    int r2d2_pos = Integer.valueOf(r2d2.substring(3));

    System.out.printf("comparing (%s, %s) to (%s, %s)\n",
            r1d1, r1d2, r2d1, r2d2);

    if (r1d1_pos != r2d1_pos)
        return r1d1_pos - r2d1_pos;

    if (r1d2_pos != r2d2_pos)
        return r1d2_pos - r2d2_pos;

    return 0;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:27,代碼來源:TestPlansGroupBySuite.java

示例2: setOutput

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
public void setOutput(VoltTable...output) {
    if (output == null || output.length == 0) return;
    this.output = new Object[output.length][][];
    
    this.output_types = new VoltType[output.length][];
    for (int i = 0; i < this.output.length; i++) {
        VoltTable vt = output[i];
        if (vt == null) continue;
        
        // TYPES
        this.output_types[i] = new VoltType[vt.getColumnCount()];
        for (int k = 0; k < this.output_types[i].length; k++) {
            this.output_types[i][k] = vt.getColumnType(k);
        } // FOR
        
        // DATA
        this.output[i] = new Object[vt.getRowCount()][vt.getColumnCount()];
        int j = 0;
        while (vt.advanceRow()) {
            VoltTableRow row = vt.getRow();
            for (int k = 0; k < this.output[i][j].length; k++) {
                this.output[i][j][k] = row.get(k); 
            } // FOR (columns)
            j++;
        } // WHILE (rows)
    } // FOR (tables)
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:28,代碼來源:AbstractTraceElement.java

示例3: pickRandomVal

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
private Object pickRandomVal(VoltTable table, Column col)
{
    int size = table.getRowCount();
    int i_row = RandUtil.randLong(0, size - 1).intValue();
    VoltTableRow row = table.fetchRow(i_row);
    return row.get(col.getIndex(), VoltType.get((byte) col.getType()));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:8,代碼來源:AbstractLoader.java

示例4: debug

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
private void debug(ArrayList<VoltTableRow> sorted) {
    for (VoltTableRow row : sorted) {
        String d1 = (String) row.get(0, VoltType.STRING);
        String d2 = (String) row.get(1, VoltType.STRING);
        System.out.println("Row: " + d1 + ", " + d2);
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:8,代碼來源:TestPlansGroupBySuite.java

示例5: testInsertMaxValues_No_Nulls

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
public void testInsertMaxValues_No_Nulls()
throws NoConnectionsException, ProcCallException, IOException
{
    final Client client = this.getClient();

    // Insert a MAX value for each column. For the first
    // row, insert MAX in the first column, for the 5th row
    // in the 5 column, etc.

    final Object params[] = new Object[COLS + 2];

    for (int k=0; k < COLS; ++k) {

        // build the parameter list as described above
        params[0] = "";
        params[1] = pkey.incrementAndGet();
        for (int i = 0; i < COLS; i++) {
            params[i+2] = (i == k) ? m_maxValues[i] : m_midValues[i];
            assert(params[i+2] != null);
        }

        // Perform the inserts and execute selects, verifying the
        // content of the select matches the parameters passed to
        // insert

        System.out.println("testInsertMaxValues: " + k + " MAX type is " + m_types[k]);
        params[0] = "NO_NULLS";
        client.callProcedure("Insert", params);
        // verify that the row was updated
        final VoltTable[] result = client.callProcedure("Select", "NO_NULLS", pkey.get()).getResults();
        final VoltTableRow row = result[0].fetchRow(0);
        for (int i=0; i < COLS; ++i) {
            final Object obj = row.get(i+1, m_types[i]);
            assertTrue (!row.wasNull());
            assertTrue( comparisonHelper(obj, params[i+2], m_types[i]) );
        }
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:39,代碼來源:TestSQLTypesSuite.java

示例6: testInsertMinValues_No_Nulls

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
public void testInsertMinValues_No_Nulls()
    throws NoConnectionsException, ProcCallException, IOException
{
    final Client client = this.getClient();

    // Insert a MIN value for each column. For the first
    // row, insert null in the first column, for the 5th row
    // in the 5 column, etc.

    final Object params[] = new Object[COLS + 2];

    for (int k=0; k < COLS; ++k) {

        // build the parameter list as described above
        params[0] = "";
        params[1] = pkey.incrementAndGet();
        for (int i = 0; i < COLS; i++) {
            params[i+2] = (i == k) ? m_minValues[i] : m_midValues[i];
            assert(params[i+2] != null);
        }

        // Perform the inserts and execute selects, verifying the
        // content of the select matches the parameters passed to
        // insert

        System.out.println("testInsertMinValues: " + k + " MIN type is " + m_types[k]);
        params[0] = "NO_NULLS";
        client.callProcedure("Insert", params);
        final VoltTable[] result = client.callProcedure("Select", "NO_NULLS", pkey.get()).getResults();
        final VoltTableRow row = result[0].fetchRow(0);
        for (int i=0; i < COLS; ++i) {
            final Object obj = row.get(i+1, m_types[i]);
            assertTrue (!row.wasNull());
            assertTrue( comparisonHelper(obj, params[i+2], m_types[i]) );
        }
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:38,代碼來源:TestSQLTypesSuite.java

示例7: execute

import org.voltdb.VoltTableRow; //導入方法依賴的package包/類
/**
     * Execute stmt with args, and put result, which is an array of columns,
     * into map
     * 
     * @param map
     *            the container of results of executing stmt
     * @param sp
     *            the store procedure that executes stmt
     * @param stmt
     *            the SQLStmt to be executed
     * @param args
     *            the argument needed by stmt
     * @param keys
     *            the names of columns in map
     * @param value_refs
     *            the references of values matching the keys. Each reference is
     *            one of {column_index, column_name, key_name}
     * @return the size of the first VoltTable among the array of VoltTable
     *         returned by executing stmt
     */
    public static int execute(Map<String, Object[]> map, VoltProcedure sp, SQLStmt stmt, Object[] args, String[] keys, Object[] value_refs) {
        LOG.info("Executing SQL: " + stmt);
System.out.println("ProcedureUtil line 97: " + args.length);
        String debug = "PARAMS:";
        for (Object arg : args) {
            debug += " " + arg;
        }
        LOG.info(debug);

        sp.voltQueueSQL(stmt, args);
        VoltTable table = sp.voltExecuteSQL()[0];
        System.out.println(table);

        if (keys == null) {
            assert (value_refs == null);
            return -1;
        }

        assert (keys.length == value_refs.length);

        int row_count = table.getRowCount();
System.out.println("ProcedureUtil line 116: " + row_count);
        // each key corresponds to a column of length row_count
        for (String key : keys)
            map.put(key, new Object[row_count]);

        // for update, delete, insert, keys is empty
        if (keys.length > 0) {
            for (int i = 0; i < row_count; i++) {
                VoltTableRow row = table.fetchRow(i);
                for (int j = 0; j < keys.length; j++) {
                    Object[] vals = map.get(keys[j]);
                    Object ref = value_refs[j];
                    if (ref instanceof Integer) {
                        // ref is column_index
                        vals[i] = row.get(j, table.getColumnType(j));
                    } else {
                        assert (ref instanceof String);
                        int idx = table.getColumnIndex((String) ref);
                        if (idx >= 0) {
                            // ref is column_name
                            vals[i] = row.get(idx, table.getColumnType(idx));
                        } else {
                            // ref is key_name
                            if (map.get(ref).length == 1) {
                                vals[i] = map.get(ref)[0];
                            } else {
                                vals[i] = map.get(ref)[i];
                            }
                        }
                    }
                }
            }
        }

        return row_count;
    }
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:78,代碼來源:ProcedureUtil.java


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