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


Java TableMetaParser類代碼示例

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


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

示例1: resultSetMetaToSchema

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
public static TableMeta resultSetMetaToSchema(ResultSetMetaData rsmd, DatabaseMetaData dbmd,
                                              String logicalTableName, String actualTableName) {
    String xml = resultSetMetaToSchemaXml(rsmd, dbmd, logicalTableName, actualTableName);
    if (xml == null) {
        return null;
    }

    TableMetaParser tableParser = new MysqlTableMetaParser();
    xml = xml.replaceFirst("<tables>", xmlHead);
    List<TableMeta> schemaList = tableParser.parse(xml);
    if (!schemaList.isEmpty()) {
        return schemaList.get(0);
    }

    return null;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:17,代碼來源:MysqlTableMetaManager.java

示例2: resultSetMetaToSchema

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
public static TableMeta resultSetMetaToSchema(ResultSetMetaData rsmd, DatabaseMetaData dbmd,
                                              String logicalTableName, String actualTableName) {

    String xml = resultSetMetaToSchemaXml(rsmd, dbmd, logicalTableName, actualTableName);
    if (xml == null) {
        return null;
    }
    xml = xml.replaceFirst("<tables>", xmlHead);
    List<TableMeta> ts = null;
    ts = TableMetaParser.parse(xml);
    if (ts != null && !ts.isEmpty()) {
        return ts.get(0);
    }

    return null;
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:17,代碼來源:MysqlTableMetaManager.java

示例3: parseSchema

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
public static StaticSchemaManager parseSchema(InputStream in) throws TddlException {
    if (in == null) {
        throw new IllegalArgumentException("in is null");
    }

    try {
        StaticSchemaManager schemaManager = new StaticSchemaManager();
        schemaManager.init();
        List<TableMeta> schemaList = TableMetaParser.parse(in);
        for (TableMeta t : schemaList) {
            schemaManager.putTable(t.getTableName(), t);
        }
        return schemaManager;
    } finally {
        IOUtils.closeQuietly(in);
    }

}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:19,代碼來源:StaticSchemaManager.java

示例4: buildReturnColumns

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
void buildReturnColumns() throws TddlException {
    if (returnColumns != null) {
        return;
    }

    returnColumns = new ArrayList();

    // 使用meta做為returncolumns
    // resultset中返回的meta信是物理表名,會導致join在構造返回對象時找不到index(表名不同/為null)
    if (meta != null) {
        returnColumns.addAll(meta.getColumns());
    } else {
        try {
            if (this.myJdbcHandler.getResultSet() == null) {
                myJdbcHandler.executeQuery(meta, isStreaming);
            }

            ResultSetMetaData rsmd = this.myJdbcHandler.getResultSet().getMetaData();
            for (int i = 1; i <= rsmd.getColumnCount(); i++) {
                boolean isUnsigned = StringUtils.containsIgnoreCase(rsmd.getColumnTypeName(i), "unsigned");
                DataType type = TableMetaParser.jdbcTypeToDataType(rsmd.getColumnType(i), isUnsigned);
                String name = rsmd.getColumnLabel(i);
                ColumnMeta cm = new ColumnMeta(null, name, type, null, true);
                returnColumns.add(cm);
            }

            meta = CursorMetaImp.buildNew(returnColumns);
            myJdbcHandler.setContext(meta, isStreaming);
        } catch (Exception e) {
            throw new TddlException(e);
        }
    }

}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:35,代碼來源:My_Cursor.java

示例5: loadDualTable

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
void loadDualTable() throws TddlException {
    ConfigDataHandler cdh = ConfigDataHandlerCity.getFileFactory(appName).getConfigDataHandler("DUAL_TABLE.xml",
        null);
    String data = cdh.getData();

    cdh.destroy();
    TableMetaParser parser = new TableMetaParser();

    TableMeta dualTable = parser.parse(data).get(0);

    this.putTable(dualTable.getTableName(), dualTable);
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:13,代碼來源:StaticSchemaManager.java

示例6: testSimple

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
@Test
public void testSimple() {
    List<TableMeta> schemaList = new TableMetaParser().parse(Thread.currentThread()
        .getContextClassLoader()
        .getResourceAsStream("config/test_table.xml"));
    System.out.println(schemaList);
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:8,代碼來源:TableMetaParserTest.java

示例7: init

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
public void init() throws TddlException {
    if (inited) {
        return;
    }
    try {
        myJdbcHandler.executeQuery(meta, isStreaming);
        // ResultSetMetaData rsmd =
        // this.myJdbcHandler.getResultSet().getMetaData();
        returnColumns = new ArrayList();
        // 使用meta做為returncolumns
        // resultset中返回的meta信是物理表名,會導致join在構造返回對象時找不到index(表名不同/為null)
        if (meta != null) {
            returnColumns.addAll(meta.getColumns());
        } else {
            ResultSetMetaData rsmd = this.myJdbcHandler.getResultSet().getMetaData();
            for (int i = 1; i <= rsmd.getColumnCount(); i++) {
                DataType type = TableMetaParser.jdbcTypeToDataType(rsmd.getColumnType(i));
                String name = rsmd.getColumnLabel(i);
                ColumnMeta cm = new ColumnMeta(null, name, type, null, true);
                returnColumns.add(cm);
            }

            meta = CursorMetaImp.buildNew(returnColumns);
            myJdbcHandler.setContext(meta, isStreaming);
        }
        inited = true;
    } catch (SQLException e) {
        throw new TddlException(e);
    }
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:31,代碼來源:My_Cursor.java

示例8: onDataRecieved

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
@Override
public void onDataRecieved(String dataId, String data) {
    if (data == null || data.isEmpty()) {
        logger.warn("schema is null, dataId is " + dataId);
        return;
    }

    InputStream sis = null;
    try {
        sis = new ByteArrayInputStream(data.getBytes());
        List<TableMeta> schemaList = TableMetaParser.parse(sis);

        schemaManager.ss.clear();

        for (TableMeta table : schemaList) {
            schemaManager.putTable(table.getTableName(), table);
        }

        logger.warn("table fetched:");
        logger.warn(schemaManager.ss.keySet().toString());
    } catch (Exception e) {
        logger.error("table parser error, schema file is:" + data, e);
        throw new TddlRuntimeException(e);
    } finally {
        IOUtils.closeQuietly(sis);
    }

}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:29,代碼來源:StaticSchemaManager.java

示例9: testSimple

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
@Test
public void testSimple() {
    List<TableMeta> tables = TableMetaParser.parse(Thread.currentThread()
        .getContextClassLoader()
        .getResourceAsStream("config/test_table.xml"));
    System.out.println(tables);
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:8,代碼來源:TableMetaParserTest.java

示例10: doInit

import com.taobao.tddl.optimizer.config.table.parse.TableMetaParser; //導入依賴的package包/類
protected void doInit() throws TddlException {
    super.doInit();
    ss = new ConcurrentHashMap<String, TableMeta>();

    if (this.appName == null) {
        logger.warn("schema appname is not assigned");
    }

    if (this.schemaFilePath == null) {
        logger.warn("schema file is not assigned");
    }

    if (appName == null && schemaFilePath == null) {
        return;
    }

    ConfigDataHandlerFactory factory = null;
    String dataId = null;

    // 優先從文件獲取
    if (schemaFilePath == null) {
        dataId = TDDL5_SCHEMA_DATA_ID.format(new Object[] { appName });
        factory = ConfigDataHandlerCity.getFactory(appName, unitName);
    } else {
        factory = ConfigDataHandlerCity.getFileFactory(appName);
        dataId = schemaFilePath;
    }

    schemaCdh = factory.getConfigDataHandler(dataId, new SchemaConfigDataListener(this));

    String data = schemaCdh.getData(ConfigDataHandler.GET_DATA_TIMEOUT,
        ConfigDataHandler.FIRST_CACHE_THEN_SERVER_STRATEGY);

    if (data == null) {
        schemaCdh.destory();
        // 嘗試找一下andor的版本配置
        dataId = ANDOR_SCHEMA_DATA_ID.format(new Object[] { appName });
        schemaCdh = factory.getConfigDataHandler(dataId, new SchemaConfigDataListener(this));
        data = schemaCdh.getData(ConfigDataHandler.GET_DATA_TIMEOUT,
            ConfigDataHandler.FIRST_CACHE_THEN_SERVER_STRATEGY);

    }

    if (data == null) {
        logger.warn(schemaNullError.format(new Object[] { appName, unitName, schemaFilePath, dataId }));
        return;
    }

    InputStream sis = null;
    try {
        sis = new ByteArrayInputStream(data.getBytes());
        List<TableMeta> schemaList = TableMetaParser.parse(sis);

        this.ss.clear();

        for (TableMeta table : schemaList) {
            this.putTable(table.getTableName(), table);
        }

        logger.warn("table fetched:");
        logger.warn(this.ss.keySet().toString());
    } catch (Exception e) {
        logger.error("table parser error, schema file is:\n" + data, e);
        throw new TddlRuntimeException(e);
    } finally {
        IOUtils.closeQuietly(sis);
    }

}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:70,代碼來源:StaticSchemaManager.java


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