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


Java Encoder類代碼示例

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


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

示例1: debugJSON

import org.voltdb.utils.Encoder; //導入依賴的package包/類
/**
 * @param catalog_stmt
 * @return
 */
public static String debugJSON(Statement catalog_stmt) {
    String jsonString = Encoder.hexDecodeToString(catalog_stmt.getFullplan());
    String line = "\n----------------------------------------\n";
    String ret = "FULL PLAN ORIG STRING:\n" + jsonString + line;

    for (PlanFragment catalog_frgmt : catalog_stmt.getFragments()) {
        jsonString = Encoder.hexDecodeToString(catalog_frgmt.getPlannodetree());
        try {
            JSONObject jsonObject = new JSONObject(jsonString);
            ret += "FRAGMENT " + catalog_frgmt.getName() + "\n" + jsonObject.toString(2) + line;
        } catch (Exception ex) {
            ex.printStackTrace();
            throw new RuntimeException(ex);
        }
    } // FOR
    return (ret);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:22,代碼來源:CatalogUtil.java

示例2: compileSQL

import org.voltdb.utils.Encoder; //導入依賴的package包/類
public static AbstractPlanNode compileSQL(final Procedure catalog_proc, String name, String sql) throws Exception {
    VoltCompiler compiler = new VoltCompiler();
    HSQLInterface hsql = HSQLInterface.loadHsqldb();

    Database catalog_db = (Database) catalog_proc.getParent();
    Catalog catalog = catalog_db.getCatalog();
    Statement catalog_stmt = catalog_proc.getStatements().add(name);

    StatementCompiler.compile(compiler, hsql, catalog, catalog_db, new DatabaseEstimates(), catalog_stmt, sql, true);

    // HACK: For now just return the PlanNodeList from the first fragment
    System.err.println("CATALOG_STMT: " + CatalogUtil.debug(catalog_stmt.getFragments()));
    assert (catalog_stmt.getFragments().get(0) != null);
    String serialized = catalog_stmt.getFragments().get(0).getPlannodetree();
    String jsonString = Encoder.hexDecodeToString(serialized);
    PlanNodeList list = null; // FIXME
                              // (PlanNodeList)PlanNodeTree.fromJSONObject(new
                              // JSONObject(jsonString), catalog_db);
    return (list.getRootPlanNode());
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:21,代碼來源:CompilerUtil.java

示例3: compileToCatalog

import org.voltdb.utils.Encoder; //導入依賴的package包/類
public void compileToCatalog(Catalog catalog, Database db) throws VoltCompilerException {
    String hexDDL = Encoder.hexEncode(m_fullDDL);
    catalog.execute("set " + db.getPath() + " schema \"" + hexDDL + "\"");

    String xmlCatalog;
    try {
        xmlCatalog = m_hsql.getXMLFromCatalog();
    } catch (HSQLParseException e) {
        String msg = "DDL Error: " + e.getMessage();
        throw m_compiler.new VoltCompilerException(msg);
    }

    // output the xml catalog to disk
    PrintStream ddlXmlOutput = BuildDirectoryUtils.getDebugOutputPrintStream("schema-xml", "hsql-catalog-output.xml");
    ddlXmlOutput.println(xmlCatalog);
    ddlXmlOutput.close();

    // build the local catalog from the xml catalog
    fillCatalogFromXML(catalog, db, xmlCatalog);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:21,代碼來源:DDLCompiler.java

示例4: getExplainPlans

import org.voltdb.utils.Encoder; //導入依賴的package包/類
/**
 * Get textual explain plan info for each plan from the
 * catalog to be shoved into the catalog jarfile.
 */
HashMap<String, byte[]> getExplainPlans(Catalog catalog) {
    HashMap<String, byte[]> retval = new HashMap<String, byte[]>();
    Database db = getCatalogDatabase();
    assert(db != null);
    for (Procedure proc : db.getProcedures()) {
        for (Statement stmt : proc.getStatements()) {
            String s = "SQL: " + stmt.getSqltext() + "\n";
            s += "COST: " + Integer.toString(stmt.getCost()) + "\n";
            s += "PLAN:\n\n";
            s += Encoder.hexDecodeToString(stmt.getExplainplan()) + "\n";
            byte[] b = s.getBytes(Constants.UTF8ENCODING);
            retval.put(proc.getTypeName() + "_" + stmt.getTypeName() + ".txt", b);
        }
    }
    return retval;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:21,代碼來源:VoltCompiler.java

示例5: run

import org.voltdb.utils.Encoder; //導入依賴的package包/類
public long run(byte[][] data1, String[] data2, byte[][] data3) {
    for (byte[] b : data1) {
        if (new String(b, Constants.UTF8ENCODING).equals("Hello") == false) {
            throw new VoltAbortException("bad match a");
        }
    }
    for (String s : data2) {
        if (s.equals("Hello") == false) {
            throw new VoltAbortException("bad match b");
        }
    }
    if (Encoder.hexEncode(data3[0]).equalsIgnoreCase("AAbbff00") == false) {
        throw new VoltAbortException("bad match d");
    }
    if (Encoder.hexEncode(data3[1]).equalsIgnoreCase("AAbbff0011") == false) {
        throw new VoltAbortException("bad match e");
    }
    if (Encoder.hexEncode(data3[2]).equalsIgnoreCase("1234567890abcdef") == false) {
        throw new VoltAbortException("bad match f");
    }

    return 0;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:24,代碼來源:BufferArrayProc.java

示例6: FragIdAndText

import org.voltdb.utils.Encoder; //導入依賴的package包/類
@SuppressWarnings("deprecation")
FragIdAndText(String stmtName) {
    Statement stmt = m_testProc.getStatements().getIgnoreCase(stmtName);
    PlanFragment frag = null;
    for (PlanFragment f : stmt.getFragments()) {
        frag = f;
    }

    fragId = CatalogUtil.getUniqueIdForFragment(frag);
    sqlText = stmt.getSqltext();

    ActivePlanRepository.addFragmentForTest(
            fragId,
            Encoder.decodeBase64AndDecompressToBytes(frag.getPlannodetree()),
            sqlText);
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:17,代碼來源:TestFragmentProgressUpdate.java

示例7: deserializeExpression

import org.voltdb.utils.Encoder; //導入依賴的package包/類
/**
 * @param catalog_db
 * @param exptree
 * @return
 * @throws Exception
 */
public static AbstractExpression deserializeExpression(Database catalog_db, String exptree) throws Exception {
    AbstractExpression exp = null;
    if (exptree != null && !exptree.isEmpty()) {
        JSONObject json_obj = new JSONObject(Encoder.hexDecodeToString(exptree));
        exp = AbstractExpression.fromJSONObject(json_obj, catalog_db);
    }
    return (exp);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:15,代碼來源:ExpressionUtil.java

示例8: getHexEncodedBytes

import org.voltdb.utils.Encoder; //導入依賴的package包/類
/**
 * Get a ascii-string-safe version of the binary value using a
 * hex encoding.
 *
 * @return A hex-encoded string value representing the serialized
 * objects.
 */
public String getHexEncodedBytes() {
    buffer.b.flip();
    byte bytes[] = new byte[buffer.b.remaining()];
    buffer.b.get(bytes);
    String hex = Encoder.hexEncode(bytes);
    buffer.discard();
    return hex;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:16,代碼來源:FastSerializer.java

示例9: shouldAccept

import org.voltdb.utils.Encoder; //導入依賴的package包/類
@Override
public ClientResponseImpl shouldAccept(AuthUser user,
                            StoredProcedureInvocation invocation,
                            Procedure sysProc) {
    if (!invocation.procName.equals("@UpdateApplicationCatalog")) {
        return null;
    }

    ParameterSet params = invocation.getParams();
    // Either the catalog bytes or the deployment string can be null, indicating
    // that the user doesn't want to change that component.  Null values will
    // be populated correctly by the AsyncCompilerAgentHelper downstream.
    if (params.toArray().length != 2)
    {
        return new ClientResponseImpl(ClientResponseImpl.UNEXPECTED_FAILURE,
                new VoltTable[0],
                "UpdateApplicationCatalog system procedure requires exactly " +
                "two parameters, the catalog bytes and the deployment file " +
                "string (either of which may be null).",
                invocation.clientHandle);
    }
    if (params.toArray()[0] != null)
    {
        boolean isHex = false;
        if (params.toArray()[0] instanceof String) {
            isHex = Encoder.isHexEncodedString((String) params.toArray()[0]);
        }
        if (!isHex && !(params.toArray()[0] instanceof byte[])) {
            return new ClientResponseImpl(ClientResponseImpl.UNEXPECTED_FAILURE,
                    new VoltTable[0],
                    "UpdateApplicationCatalog system procedure takes the " +
                    "catalog bytes as a byte array. The received parameter " +
                    "is of type " + params.toArray()[0].getClass() + ".",
                    invocation.clientHandle);
        }
    }
    return null;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:39,代碼來源:UpdateCatalogAcceptancePolicy.java

示例10: initSQLStmt

import org.voltdb.utils.Encoder; //導入依賴的package包/類
public void initSQLStmt(SQLStmt stmt, Statement catStmt) {

        int fragCount = catStmt.getFragments().size();

        for (PlanFragment frag : catStmt.getFragments()) {
            byte[] planHash = Encoder.hexDecode(frag.getPlanhash());
            byte[] plan = Encoder.decodeBase64AndDecompressToBytes(frag.getPlannodetree());
            long id = ActivePlanRepository.loadOrAddRefPlanFragment(planHash, plan, catStmt.getSqltext());
            boolean transactional = frag.getNontransactional() == false;

            SQLStmt.Frag stmtFrag = new SQLStmt.Frag(id, planHash, transactional);

            if (fragCount == 1 || frag.getHasdependencies()) {
                stmt.aggregator = stmtFrag;
            }
            else {
                stmt.collector = stmtFrag;
            }
        }

        stmt.isReadOnly = catStmt.getReadonly();
        stmt.isReplicatedTableDML = catStmt.getReplicatedtabledml();

        stmt.site = m_site;

        int numStatementParamJavaTypes = catStmt.getParameters().size();
        stmt.statementParamJavaTypes = new byte[numStatementParamJavaTypes];
        for (StmtParameter param : catStmt.getParameters()) {
            stmt.statementParamJavaTypes[param.getIndex()] = (byte)param.getJavatype();
            // ??? How does the SQLStmt successfully handle IN LIST queries without
            // caching the value of param.getIsarray() here?
            // Is the array-ness also reflected in the javatype? --paul
        }
    }
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:35,代碼來源:ProcedureRunner.java

示例11: initializeHSQLBackend

import org.voltdb.utils.Encoder; //導入依賴的package包/類
static public HsqlBackend initializeHSQLBackend(long siteId,
                                                CatalogContext context)
{
    synchronized(backendLock) {
        if (m_backend == null) {
            try {
                m_backend = new HsqlBackend(siteId);
                final String binDDL = context.database.getSchema();
                final String ddl = Encoder.decodeBase64AndDecompress(binDDL);
                final String[] commands = ddl.split("\n");
                for (String command : commands) {
                    String decoded_cmd = Encoder.hexDecodeToString(command);
                    decoded_cmd = decoded_cmd.trim();
                    if (decoded_cmd.length() == 0) {
                        continue;
                    }
                    m_backend.runDDL(decoded_cmd);
                }
            }
            catch (final Exception ex) {
                hostLog.fatal("Unable to construct HSQL backend");
                VoltDB.crashLocalVoltDB(ex.getMessage(), true, ex);
            }
        }
        return m_backend;
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:28,代碼來源:HsqlBackend.java

示例12: dispatchUpdateApplicationCatalog

import org.voltdb.utils.Encoder; //導入依賴的package包/類
ClientResponseImpl dispatchUpdateApplicationCatalog(StoredProcedureInvocation task,
        ClientInputHandler handler, Connection ccxn, AuthSystem.AuthUser user)
{
    ParameterSet params = task.getParams();
    // default catalogBytes to null, when passed along, will tell the
    // catalog change planner that we want to use the current catalog.
    byte[] catalogBytes = null;
    Object catalogObj = params.toArray()[0];
    if (catalogObj != null) {
        if (catalogObj instanceof String) {
            // treat an empty string as no catalog provided
            String catalogString = (String) catalogObj;
            if (!catalogString.isEmpty()) {
                catalogBytes = Encoder.hexDecode(catalogString);
            }
        } else if (catalogObj instanceof byte[]) {
            // treat an empty array as no catalog provided
            byte[] catalogArr = (byte[]) catalogObj;
            if (catalogArr.length != 0) {
                catalogBytes = catalogArr;
            }
        }
    }
    String deploymentString = (String) params.toArray()[1];
    LocalObjectMessage work = new LocalObjectMessage(
            new CatalogChangeWork(
                m_siteId,
                task.clientHandle, handler.connectionId(), ccxn.getHostnameAndIPAndPort(),
                handler.isAdmin(), ccxn, catalogBytes, deploymentString,
                task.procName, task.type, task.originalTxnId, task.originalUniqueId,
                VoltDB.instance().getReplicationRole() == ReplicationRole.REPLICA,
                VoltDB.instance().getCatalogContext().cluster.getUseddlschema(),
                m_adhocCompletionHandler, user));

    m_mailbox.send(m_plannerSiteId, work);
    return null;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:38,代碼來源:ClientInterface.java

示例13: getHexEncodedBytes

import org.voltdb.utils.Encoder; //導入依賴的package包/類
/**
 * Get a ascii-string-safe version of the binary value using a
 * hex encoding.
 *
 * @return A hex-encoded string value representing the serialized
 * objects.
 */
public String getHexEncodedBytes() {
    buffer.b().flip();
    byte bytes[] = new byte[buffer.b().remaining()];
    buffer.b().get(bytes);
    String hex = Encoder.hexEncode(bytes);
    buffer.discard();
    return hex;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:16,代碼來源:FastSerializer.java

示例14: toString

import org.voltdb.utils.Encoder; //導入依賴的package包/類
@Override
public String toString() {
    StringBuilder sb = new StringBuilder();
    sb.append(String.format("FRAGMENT PLAN HASH: %s\n", Encoder.hexEncode(m_planHash)));
    if (m_parameterSet != null) {
        ParameterSet pset = null;
        try {
            pset = ParameterSet.fromByteBuffer(m_parameterSet.asReadOnlyBuffer());
        } catch (IOException e) {
            e.printStackTrace();
        }
        assert(pset != null);
        sb.append("\n  ").append(pset.toString());
    }
    if (m_outputDepId != null) {
        sb.append("\n");
        sb.append("  OUTPUT_DEPENDENCY_ID ");
        sb.append(m_outputDepId);
    }
    if ((m_inputDepIds != null) && (m_inputDepIds.size() > 0)) {
        sb.append("\n");
        sb.append("  INPUT_DEPENDENCY_IDS ");
        for (long id : m_inputDepIds)
            sb.append(id).append(", ");
        sb.setLength(sb.lastIndexOf(", "));
    }
    if ((m_fragmentPlan != null) && (m_fragmentPlan.length != 0)) {
        sb.append("\n");
        sb.append("  FRAGMENT_PLAN ");
        sb.append(m_fragmentPlan);
    }
    if ((m_stmtText != null) && (m_stmtText.length != 0)) {
        sb.append("\n");
        sb.append("  STATEMENT_TEXT ");
        sb.append(m_stmtText);
    }
    return sb.toString();
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:39,代碼來源:FragmentTaskMessage.java

示例15: writePlanBytes

import org.voltdb.utils.Encoder; //導入依賴的package包/類
/**
 * Update the plan fragment and return the bytes of the plan
 */
static byte[] writePlanBytes(VoltCompiler compiler, PlanFragment fragment, AbstractPlanNode planGraph)
throws VoltCompilerException {
    // get the plan bytes
    PlanNodeList node_list = new PlanNodeList(planGraph);
    String json = node_list.toJSONString();
    compiler.captureDiagnosticJsonFragment(json);
    // Place serialized version of PlanNodeTree into a PlanFragment
    byte[] jsonBytes = json.getBytes(Charsets.UTF_8);
    String bin64String = Encoder.compressAndBase64Encode(jsonBytes);
    fragment.setPlannodetree(bin64String);
    return jsonBytes;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:16,代碼來源:StatementCompiler.java


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