本文整理匯總了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;
}
示例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;
}
示例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);
}
}
示例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);
}
}
}
示例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);
}
示例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);
}
示例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);
}
}
示例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);
}
}
示例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);
}
示例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);
}
}