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


Java TableMeta類代碼示例

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


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

示例1: resultSetMetaToSchema

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的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: getTable0

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
private TableMeta getTable0(String tableName) {
    TargetDB targetDB = rule.shardAny(tableName);
    TableMeta ts = null;
    if (targetDB.getDbIndex() == null) {
        // 沒有對應的規則,也沒有default group,則可能是一個不存在的表
        // 嘗試找一下local
        ts = local.getTable(tableName);
    } else {
        Group group = matrix.getGroup(targetDB.getDbIndex()); // 先找到group

        if (group == null) {
            throw new TddlRuntimeException(ErrorCode.ERR_CONFIG, "not found groupName : " + targetDB.getDbIndex());
        }
        try {
            ts = repos.get(group).getTable(tableName, targetDB.getTableNames().iterator().next());
        } catch (ExecutionException e) {
            logger.error(ErrorCode.ERR_CONFIG.getMessage("not found table : " + tableName), e);
        }
    }

    return ts;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:23,代碼來源:RuleSchemaManager.java

示例3: findBestIndexByAllColumnsSelected

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
/**
 * 根據查詢字段,查找一個索引包含所有選擇列,並且包含的無關列最少則選擇該索引
 */
public static IndexMeta findBestIndexByAllColumnsSelected(TableMeta tableMeta, List<ISelectable> queryColumns,
                                                          Map<String, Object> extraCmd) {
    if (!chooseIndex(extraCmd)) {
        return null;
    }

    IndexMeta indexChoosed = null;
    int theLeastColumnsNumber = Integer.MAX_VALUE;
    List<IndexMeta> indexs = tableMeta.getIndexs();
    for (int i = 0; i < indexs.size(); i++) {
        List<ISelectable> indexColumns = OptimizerUtils.columnMetaListToIColumnList(indexs.get(i).getKeyColumns());
        if (indexColumns.containsAll(queryColumns)) {
            if (theLeastColumnsNumber > indexs.get(i).getKeyColumns().size()) {
                theLeastColumnsNumber = indexs.get(i).getKeyColumns().size();
                indexChoosed = indexs.get(i);
            }
        }
    }

    return indexChoosed;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:25,代碼來源:IndexChooser.java

示例4: getTable

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
public ITable getTable(TableMeta table_schema, String groupNode, String actualTableName) throws TddlException {
    ITable table = tables.get(table_schema.getTableName());
    if (table == null) {
        synchronized (this) {
            table = tables.get(table_schema.getTableName());
            if (table == null) {
                try {
                    table = initTable(table_schema);
                } catch (ReplicaWriteException ex) {
                    throw new TddlNestableRuntimeException(ex);
                }
                if (!table_schema.isTmp()) {
                    tables.put(table_schema.getTableName(), table);
                }
            }

        }
    }
    return table;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:22,代碼來源:JE_Repository.java

示例5: HbCursor

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
public HbCursor(IndexMeta indexMeta, HbOperate hbOperate, TablePhysicalSchema physicalSchema, TableMeta schema,
                IQuery query){
    this.indexMeta = indexMeta;
    this.cursorMeta = ExecUtils.convertToICursorMeta(this.indexMeta);
    this.columnMap = new HashMap<String, ColumnMeta>();
    this.columnIndex = new HashMap<String, Integer>();
    for (ColumnMeta cm : cursorMeta.getColumns()) {
        columnMap.put(cm.getName(), cm);
        Integer index = cursorMeta.getIndex(indexMeta.getTableName(), cm.getName(), cm.getAlias());
        columnIndex.put(cm.getName(), index);
    }

    this.hbOperate = hbOperate;
    this.physicalSchema = physicalSchema;
    this.schema = schema;
    this.query = query;

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

示例6: resultSetMetaToSchema

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的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

示例7: getTable0

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
public TableMeta getTable0(String tableName) {
    TargetDB targetDB = rule.shardAny(tableName);
    TableMeta ts = null;
    if (targetDB.getDbIndex() == null) {
        // 沒有對應的規則,也沒有default group,則可能是一個不存在的表
        // 嘗試找一下local
        ts = local.getTable(tableName);
    } else {
        Group group = matrix.getGroup(targetDB.getDbIndex()); // 先找到group
        try {
            ts = repos.get(group).getTable(tableName, targetDB.getTableNames().iterator().next());
        } catch (ExecutionException e) {
            throw new OptimizerException(e);
        }
    }

    if (ts == null) {
        throw new TddlRuntimeException(tableName + " is not found");
    }

    return ts;
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:23,代碼來源:RuleSchemaManager.java

示例8: getTable

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
public ITable getTable(TableMeta table_schema, String groupNode) throws TddlException {
    ITable table = tables.get(table_schema.getTableName());
    if (table == null) {
        synchronized (this) {
            table = tables.get(table_schema.getTableName());
            if (table == null) {
                try {
                    table = initTable(table_schema);
                } catch (ReplicaWriteException ex) {
                    throw new TddlException(ExceptionErrorCodeUtils.Read_only, ex);
                }
                if (!table_schema.isTmp()) {
                    tables.put(table_schema.getTableName(), table);
                }
            }

        }
    }
    return table;
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:22,代碼來源:JE_Repository.java

示例9: nestBuildTableAndSchema

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
/**
 * 準備indexMeta和ITable信息
 * 
 * @param tableAndIndex
 */
protected void nestBuildTableAndSchema(String groupDataNode, TableAndIndex tableAndIndex,
                                       ExecutionContext executionContext, String indexName, String actualTable,
                                       boolean logicalIndex) throws TddlException {
    if (indexName != null && !"".equals(indexName)) {
        String tableName = ExecUtils.getLogicTableName(indexName);
        TableMeta ts = getTableMeta(tableName);
        tableAndIndex.index = ts.getIndexMeta(indexName);
        tableAndIndex.table = executionContext.getCurrentRepository().getTable(ts, groupDataNode, actualTable);
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:16,代碼來源:HandlerCommon.java

示例10: getTable

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
public ITable getTable(final TableMeta meta, final String groupNode, String actualTableName) throws TddlException {
    if (meta.isTmp()) {
        return getTempTable(meta);
    } else {
        try {
            return tables.get(groupNode).get(meta);
        } catch (ExecutionException e) {
            throw new TddlNestableRuntimeException(e);
        }
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:13,代碼來源:My_Repository.java

示例11: doInit

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
protected void doInit() throws TddlException {
    super.doInit();

    if (local != null) {
        local.init();
    }
    repos = CacheBuilder.newBuilder().build(new CacheLoader<Group, RepoSchemaManager>() {

        @Override
        public RepoSchemaManager load(Group group) throws Exception {
            RepoSchemaManager repo = new RepoSchemaManager();
            repo.setGroup(group);
            repo.setLocal(local);
            repo.setRule(rule);
            repo.init();
            return repo;
        }
    });

    cache = CacheBuilder.newBuilder()
        .maximumSize(1000)
        .expireAfterWrite(cacheExpireTime, TimeUnit.MILLISECONDS)
        .build(new CacheLoader<String, TableMeta>() {

            @Override
            public TableMeta load(String tableName) throws Exception {
                return getTable0(tableName);

            }
        });
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:33,代碼來源:RuleSchemaManager.java

示例12: getTable

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
public TableMeta getTable(String tableName) {
    // if (tableName.equals(DUAL)) {
    // return buildDualTable();
    // }

    TableMeta meta = null;
    if (local != null) {// 本地如果開啟了,先找本地
        meta = local.getTable(tableName);
    }

    if (meta != null) {
        return meta;
    }

    if (useCache) {
        try {
            meta = cache.get(tableName);
        } catch (Throwable e) {
            throw new TddlRuntimeException(ErrorCode.ERR_CONFIG, e, "not found table : " + tableName);
        }
    } else {
        meta = this.getTable0(tableName);
    }

    return meta;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:28,代碼來源:RuleSchemaManager.java

示例13: putTable

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
public void putTable(String tableName, TableMeta tableMeta) {
    if (local != null) {
        local.putTable(tableName, tableMeta);
    } else if (useCache) {
        cache.put(tableName, tableMeta);
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:9,代碼來源:RuleSchemaManager.java

示例14: getAllTables

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
@Override
public Collection<TableMeta> getAllTables() {
    List<TableMeta> metas = new ArrayList();
    if (local != null) {
        metas.addAll(local.getAllTables());
    }

    if (cache != null) {
        metas.addAll(cache.asMap().values());
    }

    return metas;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:14,代碼來源:RuleSchemaManager.java

示例15: buildDualTable

import com.taobao.tddl.optimizer.config.table.TableMeta; //導入依賴的package包/類
protected TableMeta buildDualTable() {
    IndexMeta index = new IndexMeta(SchemaManager.DUAL,
        new ArrayList<ColumnMeta>(),
        new ArrayList<ColumnMeta>(),
        IndexType.NONE,
        Relationship.NONE,
        false,
        true);

    return new TableMeta(DUAL, new ArrayList<ColumnMeta>(), index, new ArrayList<IndexMeta>());
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:12,代碼來源:RuleSchemaManager.java


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