From d464a27b3c6e70ef87e62117704a08889dcea3f5 Mon Sep 17 00:00:00 2001 From: tangenta Date: Wed, 19 Aug 2020 19:15:07 +0800 Subject: [PATCH] ddl: fix db charset modification panic in an uppercase schema (#19286) --- ddl/db_integration_test.go | 7 +++++++ infoschema/builder.go | 3 ++- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/ddl/db_integration_test.go b/ddl/db_integration_test.go index b22d0514227ba..8d07b37929098 100644 --- a/ddl/db_integration_test.go +++ b/ddl/db_integration_test.go @@ -1931,6 +1931,13 @@ func (s *testIntegrationSuite5) TestChangingDBCharset(c *C) { tk.MustExec("ALTER SCHEMA CHARACTER SET = 'utf8mb4' COLLATE = 'utf8mb4_general_ci'") verifyDBCharsetAndCollate("alterdb2", "utf8mb4", "utf8mb4_general_ci") + + // Test changing charset of schema with uppercase name. See https://github.com/pingcap/tidb/issues/19273. + tk.MustExec("drop database if exists TEST_UPPERCASE_DB_CHARSET;") + tk.MustExec("create database TEST_UPPERCASE_DB_CHARSET;") + tk.MustExec("use TEST_UPPERCASE_DB_CHARSET;") + tk.MustExec("alter database TEST_UPPERCASE_DB_CHARSET default character set utf8;") + tk.MustExec("alter database TEST_UPPERCASE_DB_CHARSET default character set utf8mb4;") } func (s *testIntegrationSuite4) TestDropAutoIncrementIndex(c *C) { diff --git a/infoschema/builder.go b/infoschema/builder.go index 9b2fb7ffcfcd7..6c38352528ff3 100644 --- a/infoschema/builder.go +++ b/infoschema/builder.go @@ -206,7 +206,7 @@ func (b *Builder) applyModifySchemaCharsetAndCollate(m *meta.Meta, diff *model.S fmt.Sprintf("(Schema ID %d)", diff.SchemaID), ) } - newDbInfo := b.copySchemaTables(di.Name.O) + newDbInfo := b.copySchemaTables(di.Name.L) newDbInfo.Charset = di.Charset newDbInfo.Collate = di.Collate return nil @@ -381,6 +381,7 @@ func (b *Builder) copySchemasMap(oldIS *infoSchema) { // copySchemaTables creates a new schemaTables instance when a table in the database has changed. // It also does modifications on the new one because old schemaTables must be read-only. +// Note: please make sure the dbName is in lowercase. func (b *Builder) copySchemaTables(dbName string) *model.DBInfo { oldSchemaTables := b.is.schemaMap[dbName] newSchemaTables := &schemaTables{