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


Java Catalog類代碼示例

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


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

示例1: compile

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
static void compile(VoltCompiler compiler, HSQLInterface hsql, DatabaseEstimates estimates, Catalog catalog, Database db, ProcedureDescriptor procedureDescriptor)
        throws VoltCompiler.VoltCompilerException {

    assert (compiler != null);
    assert (hsql != null);
    assert (estimates != null);

    if (procedureDescriptor.m_singleStmt == null) {
        final String className = procedureDescriptor.m_className;
        Class<?> procClass = null;
        try {
            procClass = Class.forName(className);
        } catch (ClassNotFoundException e) {
            String msg = "Cannot load class for procedure: " + className;
            throw compiler.new VoltCompilerException(msg);
        }

        if (ClassUtil.getSuperClasses(procClass).contains(VoltTrigger.class)) {
            compileTriggerProcedure(procClass, compiler, hsql, estimates, catalog, db, procedureDescriptor);
        } else
            compileJavaProcedure(compiler, hsql, estimates, catalog, db, procedureDescriptor);
    } else
        compileSingleStmtProcedure(compiler, hsql, estimates, catalog, db, procedureDescriptor);

}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:26,代碼來源:ProcedureCompiler.java

示例2: testGetStats

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
public void testGetStats() throws Exception {
    final Catalog catalog = new Catalog();
    catalog.execute(LoadCatalogToString.THE_CATALOG);
    sourceEngine.loadCatalog(catalog.serialize());

    final int WAREHOUSE_TABLEID = catalog.getClusters().get("cluster").getDatabases().get("database").getTables().get("WAREHOUSE").getRelativeIndex();
    final int STOCK_TABLEID = catalog.getClusters().get("cluster").getDatabases().get("database").getTables().get("STOCK").getRelativeIndex();
    final int locators[] = new int[] { WAREHOUSE_TABLEID, STOCK_TABLEID };
    final VoltTable results[] = sourceEngine.getStats(SysProcSelector.TABLE, locators, false, 0L);
    assertNotNull(results);
    assertEquals(1, results.length);
    assertNotNull(results[0]);
    final VoltTable resultTable = results[0];
    assertEquals(2, resultTable.getRowCount());
    while (resultTable.advanceRow()) {
        String tn = resultTable.getString("TABLE_NAME");
        assertTrue(tn.equals("WAREHOUSE") || tn.equals("STOCK"));
    }
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:20,代碼來源:TestExecutionEngine.java

示例3: cloneConstraints

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
/**
 * @param src_db
 * @param dest_db
 */
public static void cloneConstraints(Database src_db, Database dest_db) {
    Catalog dest_catalog = dest_db.getCatalog();
    for (Table src_tbl : src_db.getTables()) {
        Table dest_tbl = dest_db.getTables().get(src_tbl.getName());
        if (dest_tbl != null) {
            for (Constraint src_cons : src_tbl.getConstraints()) {
                // Only clone FKEY constraint if the other table is in the catalog
                ConstraintType cons_type = ConstraintType.get(src_cons.getType());
                if (cons_type != ConstraintType.FOREIGN_KEY || (cons_type == ConstraintType.FOREIGN_KEY && dest_db.getTables().get(src_cons.getForeignkeytable().getName()) != null)) {
                    Constraint dest_cons = clone(src_cons, dest_catalog);
                    assert (dest_cons != null);
                }
            } // FOR
        }
    } // FOR
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:21,代碼來源:CatalogCloner.java

示例4: createTPCCSchemaCatalog

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
public Catalog createTPCCSchemaCatalog(boolean fkeys) throws IOException {
    // compile a catalog
    String testDir = BuildDirectoryUtils.getBuildDirectoryPath();
    String catalogJar = testDir + File.separator + this.getJarName(true);

    addSchema(this.getDDLURL(fkeys));
    addDefaultPartitioning();
    addDefaultProcedures();
    //this.addProcedures(org.voltdb.benchmark.tpcc.procedures.InsertHistory.class);

    boolean status = compile(catalogJar);
    assert(status);

    // read in the catalog
    String serializedCatalog = CatalogUtil.loadCatalogFromJar(catalogJar, null);
    assert(serializedCatalog != null);

    // create the catalog (that will be passed to the ClientInterface
    Catalog catalog = new Catalog();
    catalog.execute(serializedCatalog);

    return catalog;
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:24,代碼來源:TPCCProjectBuilder.java

示例5: compileSQL

import org.voltdb.catalog.Catalog; //導入依賴的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

示例6: compileCatalog

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
/**
 * Generate a new catalog object for the given schema
 * 
 * @param schema_file
 * @return
 * @throws Exception
 */
public static Catalog compileCatalog(String schema_file) throws Exception {

    HSQLInterface hzsql = HSQLInterface.loadHsqldb();
    String xmlSchema = null;
    hzsql.runDDLFile(schema_file);
    xmlSchema = hzsql.getXMLFromCatalog(true);

    //
    // Setup fake database connection. Pass stuff to database to get catalog
    // objects
    //
    Catalog catalog = new Catalog();
    catalog.execute("add / clusters " + CatalogUtil.DEFAULT_CLUSTER_NAME);
    catalog.execute("add /clusters[" + CatalogUtil.DEFAULT_CLUSTER_NAME + "] databases " + CatalogUtil.DEFAULT_DATABASE_NAME);
    Database catalog_db = catalog.getClusters().get(CatalogUtil.DEFAULT_CLUSTER_NAME).getDatabases().get(CatalogUtil.DEFAULT_DATABASE_NAME);

    VoltCompiler compiler = new VoltCompiler();
    DDLCompiler ddl_compiler = new DDLCompiler(compiler, hzsql);
    ddl_compiler.fillCatalogFromXML(catalog, catalog_db, xmlSchema);
    return (catalog);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:29,代碼來源:CompilerUtil.java

示例7: CatalogTreeModel

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
public CatalogTreeModel(ArgumentsParser args, Catalog catalog, String catalog_path) {
    super(new DefaultMutableTreeNode(catalog.getName() + " [" + catalog_path + "]"));
    this.catalog = catalog;
    
    // Procedures to exclude in Conflict Graph
    if (args.hasParam(ArgumentsParser.PARAM_CONFLICTS_EXCLUDE_PROCEDURES)) {
        String param = args.getParam(ArgumentsParser.PARAM_CONFLICTS_EXCLUDE_PROCEDURES);
        Database catalog_db = CatalogUtil.getDatabase(this.catalog);
        for (String procName : param.split(",")) {
            Procedure catalog_proc = catalog_db.getProcedures().getIgnoreCase(procName);
            if (catalog_proc != null) {
                this.conflictGraphExcludes.add(catalog_proc);
            } else {
                LOG.warn("Invalid procedure name to exclude '" + procName + "'");
            }
        } // FOR
        LOG.debug("Excluded ConflictGraph Procedures: " + this.conflictGraphExcludes);
    }
    
    this.buildModel();
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:22,代碼來源:CatalogTreeModel.java

示例8: testSufficientHostsToReplicate

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
public void testSufficientHostsToReplicate()
{
    // 2 hosts, 6 sites per host, 2 copies of each partition.
    // there are sufficient execution sites, but insufficient hosts
    ClusterConfig config = new ClusterConfig(2, 6, 2, "localhost");
    Catalog catalog = new Catalog();
    catalog.execute("add / clusters cluster");
    boolean caught = false;
    try
    {
        ClusterCompiler.compile(catalog, config);
    }
    catch (RuntimeException e)
    {
        if (e.getMessage().contains("Insufficient hosts"))
        {
            caught = true;
        }
    }
    assertTrue(caught);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:22,代碼來源:TestClusterCompiler.java

示例9: compileXMLRootNode

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
void compileXMLRootNode(ProjectType project) throws VoltCompilerException {
    m_catalog = new Catalog();
    temporaryCatalogInit();

    SecurityType security = project.getSecurity();
    if (security != null) {
        m_catalog.getClusters().get("cluster").
            setSecurityenabled(security.isEnabled());

    }

    DatabaseType database = project.getDatabase();
    if (database != null) {
        compileDatabaseNode(database);
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:17,代碼來源:VoltCompiler.java

示例10: compileToCatalog

import org.voltdb.catalog.Catalog; //導入依賴的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

示例11: testNonZeroReplicationFactor

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
public void testNonZeroReplicationFactor()
    {
        ClusterConfig config = new ClusterConfig(3, 1, 2, "localhost");
        Catalog catalog = new Catalog();
        catalog.execute("add / clusters cluster");
        ClusterCompiler.compile(catalog, config);
        System.out.println(catalog.serialize());
        Cluster cluster = catalog.getClusters().get("cluster");
        Collection<Partition> partitions = CatalogUtil.getAllPartitions(cluster);
        // despite 3 hosts, should only have 1 partition with k-safety of 2
//        assertEquals(1, partitions.size());
//        // All the execution sites should have the same relative index
//        int part_guid = CatalogUtil.getPartitionById(cluster, 0).getRelativeIndex();
//        for (Site site : cluster.getSites())
//        {
////            if (site.getIsexec())
////            {
////                assertEquals(part_guid, site.getPartition().getRelativeIndex());
////            }
//        }
    }
 
開發者ID:s-store,項目名稱:s-store,代碼行數:22,代碼來源:TestClusterCompiler.java

示例12: addTriggerToCatalog

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
/**
 * Add a trigger to the catalog
 * 
 * @param compiler
 * @param hsql
 * @param parent
 * @param triggers
 * @param catalog
 * @param db
 * @param node
 * @throws VoltCompilerException
 */
static void addTriggerToCatalog(VoltCompiler compiler, HSQLInterface hsql, Table parent, CatalogMap<Trigger> triggers, Catalog catalog, Database db, String[] stmt, StmtInfo[] stmtInfoArr,
        int trigId) throws VoltCompilerException {
    int type = 0; // insert
    boolean forEach = false;

    Trigger trigger = triggers.add("trig" + trigId);
    trigger.setId(trigId);
    trigger.setForeach(forEach);
    trigger.setSourcetable(parent);
    trigger.setTriggertype(type);

    for (int i = 0; i < stmt.length; i++) {
        Statement s = trigger.getStatements().add("trig" + trigId + "stmt" + i);
        StmtInfo stmtInfo = (StmtInfo) stmtInfoArr[i];
        if (stmtInfo != null)
            s.setUpsertable(stmtInfo.upsertable());
        else
            s.setUpsertable(false);
        StatementCompiler.compile(compiler, hsql, catalog, db, new DatabaseEstimates(), s, stmt[i], true);
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:34,代碼來源:ProcedureCompiler.java

示例13: testCreateSchemaCatalog

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
/**
 * testCreateSchemaCatalog
 */
public void testCreateSchemaCatalog() throws Exception {
    Catalog s_catalog = new TPCEProjectBuilder().getSchemaCatalog(false);
    assertNotNull(s_catalog);
    Database s_catalog_db = CatalogUtil.getDatabase(s_catalog);
    assertNotNull(catalog_db);

    // ADDRESS should point to ZIP_CODE
    Table address = s_catalog_db.getTables().get(TPCEConstants.TABLENAME_ADDRESS);
    assertNotNull(address);
    Table zipcode = s_catalog_db.getTables().get(TPCEConstants.TABLENAME_ZIP_CODE);
    assertNotNull(zipcode);

    for (Constraint catalog_const : address.getConstraints()) {
        if (catalog_const.getType() == ConstraintType.FOREIGN_KEY.getValue()) {
            assertEquals(zipcode, catalog_const.getForeignkeytable());
            assertEquals(1, catalog_const.getForeignkeycols().size());
            break;
        }
    } // FOR
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:24,代碼來源:TestTPCEProjectBuilder.java

示例14: initializeCatalog

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
/**
 * Update the catalog to include new hosts/sites/partitions
 * @param num_hosts
 * @param num_sites
 * @param num_partitions
 * @throws Exception
 */
protected final void initializeCatalog(int num_hosts, int num_sites, int num_partitions) throws Exception {
    // HACK! If we already have this many partitions in the catalog, then we won't recreate it
    // This fixes problems where we need to reference the same catalog objects in multiple test cases
    if (catalogContext.numberOfHosts != num_hosts ||
        catalogContext.numberOfSites != (num_hosts * num_sites) ||
        catalogContext.numberOfPartitions != (num_hosts * num_sites * num_partitions)) {
        
        // HACK
        String hostFormat = (num_hosts == 1 ? "localhost" : "host%02d"); 
        Catalog c = FixCatalog.cloneCatalog(catalog, hostFormat, num_hosts, num_sites, num_partitions);
        CatalogContext cc = new CatalogContext(c, catalogContext.jarPath);
        this.init(this.last_type, cc);
    }
    Cluster cluster = catalogContext.cluster;
    assertEquals(num_hosts, catalogContext.numberOfHosts);
    assertEquals((num_hosts * num_sites), catalogContext.numberOfSites);
    assertEquals((num_hosts * num_sites * num_partitions), catalogContext.numberOfPartitions);
    assertEquals((num_hosts * num_sites * num_partitions), cluster.getNum_partitions());
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:27,代碼來源:BaseTestCase.java

示例15: ConflictSetCalculator

import org.voltdb.catalog.Catalog; //導入依賴的package包/類
public ConflictSetCalculator(Catalog catalog) {
    this.catalog_db = CatalogUtil.getDatabase(catalog);

    for (Table catalog_tbl : CatalogUtil.getDataTables(catalog_db)) {
        this.pkeysCache.put(catalog_tbl, CatalogUtil.getPrimaryKeyColumns(catalog_tbl));
    } // FOR (table)
    
    for (Procedure catalog_proc : catalog_db.getProcedures()) {
        if (catalog_proc.getMapreduce() || catalog_proc.getSystemproc()) continue;
        if (this.ignoredProcedures.contains(catalog_proc)) continue;
        
        ProcedureInfo pInfo = new ProcedureInfo(catalog_proc);
        for (Statement catalog_stmt : catalog_proc.getStatements()) {
            if (this.ignoredStatements.contains(catalog_stmt)) continue;
            QueryType qtype = QueryType.get(catalog_stmt.getQuerytype());
            if (qtype == QueryType.SELECT) {
                pInfo.readQueries.add(catalog_stmt);
            } else {
                pInfo.writeQueries.add(catalog_stmt);
            }
        } // FOR (statement)
        this.procedures.put(catalog_proc, pInfo);
    } // FOR (procedure)
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:25,代碼來源:ConflictSetCalculator.java


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