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


Java Encoder.hexEncode方法代碼示例

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


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

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

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

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

示例4: getCacheForCatalogHash

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
/**
 * Get the global cache for a given hash of the catalog. Note that there can be only
 * one cache per catalogHash at a time.
 */
public synchronized static AdHocCompilerCache getCacheForCatalogHash(byte[] catalogHash) {
    String hashString = Encoder.hexEncode(catalogHash);
    AdHocCompilerCache cache = m_catalogHashMatch.getIfPresent(hashString);
    if (cache == null) {
        cache = new AdHocCompilerCache();
        m_catalogHashMatch.put(hashString, cache);
    }
    return cache;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:14,代碼來源:AdHocCompilerCache.java

示例5: testUpdateCatalog

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
@Test
public void testUpdateCatalog() throws IOException {
    // only makes sense in pro (sysproc suite has a complementary test for community)
    if (VoltDB.instance().getConfig().m_isEnterprise) {
        String catalogHex = Encoder.hexEncode("blah");
        ByteBuffer msg = createMsg("@UpdateApplicationCatalog", catalogHex, "blah");
        ClientResponseImpl resp = m_ci.handleRead(msg, m_handler, m_cxn);
        assertNull(resp);
        ArgumentCaptor<LocalObjectMessage> captor = ArgumentCaptor.forClass(LocalObjectMessage.class);
        verify(m_messenger).send(eq(32L), // A fixed number set in setUpOnce()
                                 captor.capture());
        assertTrue(captor.getValue().payload instanceof CatalogChangeWork);
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:15,代碼來源:TestClientInterface.java

示例6: toString

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
@Override
public String toString() {
    return Encoder.hexEncode(hashBytes);
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:5,代碼來源:Sha1Wrapper.java

示例7: report

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
/**
 * Generate the HTML catalog report from a newly compiled VoltDB catalog
 */
public static String report(Catalog catalog, ArrayList<Feedback> warnings, String autoGenDDL) throws IOException {
    // asynchronously get platform properties
    new Thread() {
        @Override
        public void run() {
            PlatformProperties.getPlatformProperties();
        }
    }.start();


    URL url = Resources.getResource(ReportMaker.class, "template.html");
    String contents = Resources.toString(url, Charsets.UTF_8);

    Cluster cluster = catalog.getClusters().get("cluster");
    assert(cluster != null);
    Database db = cluster.getDatabases().get("database");
    assert(db != null);

    String statsData = getStatsHTML(db, warnings);
    contents = contents.replace("##STATS##", statsData);

    // generateProceduresTable needs to happen before generateSchemaTable
    // because some metadata used in the later is generated in the former
    String procData = generateProceduresTable(db.getTables(), db.getProcedures());
    contents = contents.replace("##PROCS##", procData);

    String schemaData = generateSchemaTable(db);
    contents = contents.replace("##SCHEMA##", schemaData);

    DatabaseSizes sizes = CatalogSizing.getCatalogSizes(db);

    String sizeData = generateSizeTable(sizes);
    contents = contents.replace("##SIZES##", sizeData);

    String sizeSummary = generateSizeSummary(sizes);
    contents = contents.replace("##SIZESUMMARY##", sizeSummary);

    String platformData = PlatformProperties.getPlatformProperties().toHTML();
    contents = contents.replace("##PLATFORM##", platformData);

    contents = contents.replace("##VERSION##", VoltDB.instance().getVersionString());

    contents = contents.replace("##DDL##", escapeHtml4(autoGenDDL));

    DateFormat df = new SimpleDateFormat("d MMM yyyy HH:mm:ss z");
    contents = contents.replace("##TIMESTAMP##", df.format(m_timestamp));

    String msg = Encoder.hexEncode(VoltDB.instance().getVersionString() + "," + System.currentTimeMillis());
    contents = contents.replace("get.py?a=KEY&", String.format("get.py?a=%s&", msg));

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

示例8: testPartitionAndInsert

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
public void testPartitionAndInsert () throws Exception {
    String my_schema =
            "create table BLAH (" +
            "clm_varinary varbinary(128) default '00' not null," +
            "clm_smallint smallint default 0 not null, " +
            ");";

        pathToCatalog = Configuration.getPathToCatalogForTest("csv.jar");
        pathToDeployment = Configuration.getPathToCatalogForTest("csv.xml");
        builder = new VoltProjectBuilder();

        builder.addLiteralSchema(my_schema);
        builder.addPartitionInfo("BLAH", "clm_varinary");
        //builder.addStmtProcedure("Insert", "INSERT into BLAH values (?, ?, ?, ?, ?, ?, ?);");
        boolean success = builder.compile(pathToCatalog, 2, 1, 0);
        assertTrue(success);
        MiscUtils.copyFile(builder.getPathToDeployment(), pathToDeployment);
        config = new VoltDB.Configuration();
        config.m_pathToCatalog = pathToCatalog;
        config.m_pathToDeployment = pathToDeployment;
        localServer = new ServerThread(config);
        client = null;

        localServer.start();
        localServer.waitForInitialization();

        client = ClientFactory.createClient();
        client.createConnection("localhost");

        ClientResponse resp;
        resp = client.callProcedure("@AdHoc", "INSERT INTO BLAH VALUES ('22',1);");
        assertEquals(1, resp.getResults()[0].asScalarLong());
        resp = client.callProcedure("@AdHoc", "INSERT INTO BLAH VALUES ('80',3);" );
        assertEquals(1, resp.getResults()[0].asScalarLong());
        resp = client.callProcedure("@AdHoc", "INSERT INTO BLAH VALUES ('8081828384858687888990',4);" );
        assertEquals(1, resp.getResults()[0].asScalarLong());

        Random rand = new Random();
        for( int i = 0; i < 1000; i++ ){
            byte[] bytes = new byte[rand.nextInt(128)];
            rand.nextBytes(bytes);
            // Just to mix things up, alternate methods of INSERT among
            // literal hex string, hex string parameter, and byte[] parameter.
            if ( i % 2 == 0 ) {
                String hexString = Encoder.hexEncode(bytes);
                if ( i % 4 == 0 ) {
                    resp = client.callProcedure("@AdHoc", "INSERT INTO BLAH VALUES ('" + hexString + "',5);" );
                } else {
                    resp = client.callProcedure("@AdHoc", "INSERT INTO BLAH VALUES (?,5);", hexString);
                }
            } else {
                resp = client.callProcedure("@AdHoc", "INSERT INTO BLAH VALUES (?,5);", bytes);
            }
            assertEquals(1, resp.getResults()[0].asScalarLong());
        }
        resp =  client.callProcedure("@AdHoc", "SELECT COUNT(*) FROM BLAH;");
        assertEquals(3 + 1000, resp.getResults()[0].asScalarLong());
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:59,代碼來源:TestVarBinaryPartition.java


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