Skip to content

Commit

Permalink
fix outputoffset
Browse files Browse the repository at this point in the history
  • Loading branch information
zhexuany committed Mar 28, 2019
1 parent ce6e612 commit 5e1d65b
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import org.apache.spark.sql.BaseInitialOnceSuite

class LogicalAndOr0Suite extends BaseInitialOnceSuite {
private val allCases = Seq[String](
"select tp_char, tp_smallint, tp_char, tp_smallint, tp_char from full_data_type_table where tp_char = tp_smallint and tp_char > 0",
"select tp_char,tp_smallint from full_data_type_table where tp_char = tp_smallint and tp_char > 0",
"select tp_char,id_dt from full_data_type_table where tp_char = id_dt and tp_char > 0",
"select tp_nvarchar,tp_tinyint from full_data_type_table where tp_nvarchar = tp_tinyint and tp_nvarchar > 0",
Expand Down
37 changes: 25 additions & 12 deletions tikv-client/src/main/java/com/pingcap/tikv/meta/TiDAGRequest.java
Original file line number Diff line number Diff line change
Expand Up @@ -356,28 +356,41 @@ else if (col.getColumnInfo().isPrimaryKey() && tableInfo.isPkHandle()) {
executorBuilder.setTp(ExecType.TypeTableScan);
tblScanBuilder.setTableId(id);
// Step1. Add columns to first executor
Map<ColumnRef, Integer> seenColsOffset = new HashMap<>();
int realOffset = 0;
for (int i = 0; i < getFields().size(); i++) {
ColumnRef col = getFields().get(i);
tblScanBuilder.addColumns(col.getColumnInfo().toProto(tableInfo));
colOffsetInFieldMap.put(col, i);
}
// Currently, according to TiKV's implementation, if handle
// is needed, we should add an extra column with an ID of -1
// to the TableScan executor
if (isHandleNeeded()) {
tblScanBuilder.addColumns(handleColumn);
// can't allow duplicated col added into executor.
if (!colOffsetInFieldMap.containsKey(col)) {
tblScanBuilder.addColumns(col.getColumnInfo().toProto(tableInfo));
colOffsetInFieldMap.put(col, realOffset);
}
if (!seenColsOffset.containsKey(col)) {
seenColsOffset.put(col, realOffset);
realOffset++;
}
}
dagRequestBuilder.addExecutors(executorBuilder.setTblScan(tblScanBuilder));

// column offset should be in accordance with fields
for (int i = 0; i < getFields().size(); i++) {
dagRequestBuilder.addOutputOffsets(i);
ColumnRef col = getFields().get(i);
if (seenColsOffset.containsKey(col)) {
dagRequestBuilder.addOutputOffsets(seenColsOffset.get(col));
}
}

// if handle is needed, we should append one output offset
// Currently, according to TiKV's implementation, if handle
// is needed, we should add an extra column with an ID of -1
// to the TableScan executor
if (isHandleNeeded()) {
dagRequestBuilder.addOutputOffsets(tableInfo.getColumns().size());
tblScanBuilder.addColumns(handleColumn);
// if handle is needed, we should append one output offset
// duplicated col may exists, we need append the size of current
// output offset's size.
dagRequestBuilder.addOutputOffsets(dagRequestBuilder.getOutputOffsetsCount());
}

dagRequestBuilder.addExecutors(executorBuilder.setTblScan(tblScanBuilder));
}

if (!isIndexScan || (isIndexScan() && !isDoubleRead())) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,8 @@ public abstract class CoprocessIterator<T> implements Iterator<T> {
public static CoprocessIterator<Row> getRowIterator(
TiDAGRequest req, List<RegionTask> regionTasks, TiSession session) {
return new DAGIterator<Row>(
// If index scan is a covering index, the logic is table scan
// so we need set isIndexScan to false.
req.buildScan(req.isIndexScan() && !req.isDoubleRead()),
regionTasks,
session,
Expand Down

0 comments on commit 5e1d65b

Please sign in to comment.