From c5322f6ca6aebb41ddff9fde4666801e903198f6 Mon Sep 17 00:00:00 2001 From: Arthur Schreiber Date: Tue, 9 Apr 2024 14:44:24 +0000 Subject: [PATCH] Skip reloading the schema --- go/vt/vttablet/tabletserver/query_executor.go | 42 +++++++++---------- 1 file changed, 21 insertions(+), 21 deletions(-) diff --git a/go/vt/vttablet/tabletserver/query_executor.go b/go/vt/vttablet/tabletserver/query_executor.go index cf26d7c5019..e9740d05c4b 100644 --- a/go/vt/vttablet/tabletserver/query_executor.go +++ b/go/vt/vttablet/tabletserver/query_executor.go @@ -636,27 +636,27 @@ func (qre *QueryExecutor) execDDL(conn *StatefulConnection) (*sqltypes.Result, e } } - isTemporaryTable := false - if ddlStmt, ok := qre.plan.FullStmt.(sqlparser.DDLStatement); ok { - isTemporaryTable = ddlStmt.IsTemporary() - } - if !isTemporaryTable { - // Temporary tables are limited to the session creating them. There is no need to Reload() - // the table because other connections will not be able to see the table anyway. - defer func() { - // Call se.Reload() with includeStats=false as obtaining table - // size stats involves joining `information_schema.tables`, - // which can be very costly on systems with a large number of - // tables. - // - // Instead of synchronously recalculating table size stats - // after every DDL, let them be outdated until the periodic - // schema reload fixes it. - if err := qre.tsv.se.ReloadAtEx(qre.ctx, mysql.Position{}, false); err != nil { - log.Errorf("failed to reload schema %v", err) - } - }() - } + // isTemporaryTable := false + // if ddlStmt, ok := qre.plan.FullStmt.(sqlparser.DDLStatement); ok { + // isTemporaryTable = ddlStmt.IsTemporary() + // } + // if !isTemporaryTable { + // // Temporary tables are limited to the session creating them. There is no need to Reload() + // // the table because other connections will not be able to see the table anyway. + // // defer func() { + // // // Call se.Reload() with includeStats=false as obtaining table + // // // size stats involves joining `information_schema.tables`, + // // // which can be very costly on systems with a large number of + // // // tables. + // // // + // // // Instead of synchronously recalculating table size stats + // // // after every DDL, let them be outdated until the periodic + // // // schema reload fixes it. + // // if err := qre.tsv.se.ReloadAtEx(qre.ctx, mysql.Position{}, false); err != nil { + // // log.Errorf("failed to reload schema %v", err) + // // } + // // }() + // } sql := qre.query // If FullQuery is not nil, then the DDL query was fully parsed // and we should use the ast to generate the query instead.