Skip to content

Commit

Permalink
*: speed up create table and reduce memory usage when the number of…
Browse files Browse the repository at this point in the history
… tables is relatively large (#49371) (#53545)

close #49370
  • Loading branch information
ti-chi-bot authored May 27, 2024
1 parent f3f5b69 commit a97e646
Show file tree
Hide file tree
Showing 4 changed files with 47 additions and 1 deletion.
2 changes: 1 addition & 1 deletion pkg/ddl/table.go
Original file line number Diff line number Diff line change
Expand Up @@ -1507,7 +1507,7 @@ func checkTableNotExistsFromInfoSchema(is infoschema.InfoSchema, schemaID int64,

func checkTableNotExistsFromStore(t *meta.Meta, schemaID int64, tableName string) error {
// Check this table's database.
tbls, err := t.ListTables(schemaID)
tbls, err := t.ListSimpleTables(schemaID)
if err != nil {
if meta.ErrDBNotExists.Equal(err) {
return infoschema.ErrDatabaseNotExists.GenWithStackByArgs("")
Expand Down
32 changes: 32 additions & 0 deletions pkg/meta/meta.go
Original file line number Diff line number Diff line change
Expand Up @@ -959,6 +959,38 @@ func (m *Meta) ListTables(dbID int64) ([]*model.TableInfo, error) {
return tables, nil
}

// ListSimpleTables shows all simple tables in database.
func (m *Meta) ListSimpleTables(dbID int64) ([]*model.TableNameInfo, error) {
dbKey := m.dbKey(dbID)
if err := m.checkDBExists(dbKey); err != nil {
return nil, errors.Trace(err)
}

res, err := m.txn.HGetAll(dbKey)
if err != nil {
return nil, errors.Trace(err)
}

tables := make([]*model.TableNameInfo, 0, len(res)/2)
for _, r := range res {
// only handle table meta
tableKey := string(r.Field)
if !strings.HasPrefix(tableKey, mTablePrefix) {
continue
}

tbInfo := &model.TableNameInfo{}
err = json.Unmarshal(r.Value, tbInfo)
if err != nil {
return nil, errors.Trace(err)
}

tables = append(tables, tbInfo)
}

return tables, nil
}

// ListDatabases shows all databases.
func (m *Meta) ListDatabases() ([]*model.DBInfo, error) {
res, err := m.txn.HGetAll(mDBs)
Expand Down
8 changes: 8 additions & 0 deletions pkg/meta/meta_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -315,6 +315,11 @@ func TestMeta(t *testing.T) {
err = m.CreateTableOrView(1, tbInfo2)
require.NoError(t, err)

tblName := &model.TableNameInfo{ID: tbInfo.ID, Name: tbInfo.Name}
tblName2 := &model.TableNameInfo{ID: tbInfo2.ID, Name: tbInfo2.Name}
tableNames, err := m.ListSimpleTables(1)
require.NoError(t, err)
require.Equal(t, []*model.TableNameInfo{tblName, tblName2}, tableNames)
tables, err := m.ListTables(1)
require.NoError(t, err)
require.Equal(t, []*model.TableInfo{tbInfo, tbInfo2}, tables)
Expand Down Expand Up @@ -350,6 +355,9 @@ func TestMeta(t *testing.T) {
require.NoError(t, err)
require.Equal(t, int64(0), n)

tableNames, err = m.ListSimpleTables(1)
require.NoError(t, err)
require.Equal(t, []*model.TableNameInfo{tblName}, tableNames)
tables, err = m.ListTables(1)
require.NoError(t, err)
require.Equal(t, []*model.TableInfo{tbInfo}, tables)
Expand Down
6 changes: 6 additions & 0 deletions pkg/parser/model/model.go
Original file line number Diff line number Diff line change
Expand Up @@ -544,6 +544,12 @@ type TableInfo struct {
TTLInfo *TTLInfo `json:"ttl_info"`
}

// TableNameInfo provides meta data describing a table name info.
type TableNameInfo struct {
ID int64 `json:"id"`
Name CIStr `json:"name"`
}

// SepAutoInc decides whether _rowid and auto_increment id use separate allocator.
func (t *TableInfo) SepAutoInc() bool {
return t.Version >= TableInfoVersion5 && t.AutoIdCache == 1
Expand Down

0 comments on commit a97e646

Please sign in to comment.