From 2b27d5c3be20464f88ae676a7f3004f30f418b8c Mon Sep 17 00:00:00 2001 From: guo-shaoge Date: Mon, 13 Feb 2023 17:28:03 +0800 Subject: [PATCH] planner: fix tiflash cannot find generated column (#41261) close pingcap/tidb#40663 --- expression/integration_test.go | 9 +++++++-- parser/mysql/type.go | 1 + planner/core/find_best_task.go | 12 +++--------- 3 files changed, 11 insertions(+), 11 deletions(-) diff --git a/expression/integration_test.go b/expression/integration_test.go index e877bc7b347b8..4d4397f2ae8a9 100644 --- a/expression/integration_test.go +++ b/expression/integration_test.go @@ -3710,18 +3710,23 @@ func TestShardIndexOnTiFlash(t *testing.T) { } } } + tk.MustExec("set @@session.tidb_isolation_read_engines = 'tiflash'") tk.MustExec("set @@session.tidb_enforce_mpp = 1") rows := tk.MustQuery("explain select max(b) from t").Rows() for _, row := range rows { line := fmt.Sprintf("%v", row) - require.NotContains(t, line, "tiflash") + if strings.Contains(line, "TableFullScan") { + require.Contains(t, line, "tiflash") + } } tk.MustExec("set @@session.tidb_enforce_mpp = 0") tk.MustExec("set @@session.tidb_allow_mpp = 0") rows = tk.MustQuery("explain select max(b) from t").Rows() for _, row := range rows { line := fmt.Sprintf("%v", row) - require.NotContains(t, line, "tiflash") + if strings.Contains(line, "TableFullScan") { + require.NotContains(t, line, "mpp[tiflash]") + } } } diff --git a/parser/mysql/type.go b/parser/mysql/type.go index c54d0f8984b63..c274493314a16 100644 --- a/parser/mysql/type.go +++ b/parser/mysql/type.go @@ -74,6 +74,7 @@ const ( PreventNullInsertFlag uint = 1 << 20 /* Prevent this Field from inserting NULL values */ EnumSetAsIntFlag uint = 1 << 21 /* Internal: Used for inferring enum eval type. */ DropColumnIndexFlag uint = 1 << 22 /* Internal: Used for indicate the column is being dropped with index */ + GeneratedColumnFlag uint = 1 << 23 /* Internal: TiFlash will check this flag and add a placeholder for this column */ ) // TypeInt24 bounds. diff --git a/planner/core/find_best_task.go b/planner/core/find_best_task.go index 20ba420fa898e..8fd56a72720ce 100644 --- a/planner/core/find_best_task.go +++ b/planner/core/find_best_task.go @@ -1876,15 +1876,9 @@ func (ds *DataSource) convertToTableScan(prop *property.PhysicalProperty, candid return invalidTask, nil } if ts.StoreType == kv.TiFlash { - for _, col := range ts.schema.Columns { - // In theory, TiFlash does not support virtual expr, but in non-mpp mode, if the cop request only contain table scan, then - // TiDB will fill the virtual column after decoding the cop response(executor.FillVirtualColumnValue), that is to say, the virtual - // columns in Cop request is just a placeholder, so TiFlash can support virtual column in cop request mode. However, virtual column - // with TiDBShard is special, it can be added using create index statement, TiFlash's ddl does not handle create index statement, so - // there is a chance that the TiDBShard's virtual column is not seen by TiFlash, in this case, TiFlash will throw column not found error - if ds.containExprPrefixUk && expression.GcColumnExprIsTidbShard(col.VirtualExpr) { - ds.SCtx().GetSessionVars().RaiseWarningWhenMPPEnforced("MPP mode may be blocked because column `" + col.OrigName + "` is a virtual column which is not supported now.") - return invalidTask, nil + for _, col := range ts.Columns { + if col.IsGenerated() && !col.GeneratedStored { + col.AddFlag(mysql.GeneratedColumnFlag) } } }