From 5dd89461fe18c882cdcbbb72bb9abede7c8de4cf Mon Sep 17 00:00:00 2001 From: Marius Posta Date: Tue, 13 Dec 2022 10:40:50 -0500 Subject: [PATCH] nstree: Catalog method cleanup This commit renames existing methods and adds a few missing pieces for the sake of consistency. Release note: None --- pkg/ccl/backupccl/restore_job.go | 14 +-- pkg/ccl/backupccl/restore_planning.go | 4 +- pkg/ccl/backupccl/show.go | 2 +- pkg/sql/catalog/dbdesc/database_test.go | 8 +- pkg/sql/catalog/descs/collection.go | 16 +-- pkg/sql/catalog/descs/collection_test.go | 14 +-- pkg/sql/catalog/descs/descriptor.go | 8 +- pkg/sql/catalog/descs/hydrate.go | 8 +- pkg/sql/catalog/funcdesc/func_desc_test.go | 16 +-- pkg/sql/catalog/hydrateddesc/hydrate.go | 6 +- .../hydrateddesc/hydratedcache_test.go | 20 ++-- .../catalog/internal/catkv/catalog_query.go | 2 +- .../catalog/internal/catkv/catalog_reader.go | 2 +- .../internal/catkv/catalog_reader_cached.go | 10 +- .../internal/catkv/catalog_reader_test.go | 8 +- pkg/sql/catalog/internal/catkv/direct.go | 2 +- pkg/sql/catalog/internal/catkv/validate.go | 2 +- pkg/sql/catalog/nstree/catalog.go | 105 +++++++++++++++--- pkg/sql/catalog/nstree/catalog_mutable.go | 72 ++++-------- .../catalog/schemadesc/schema_desc_test.go | 4 +- .../schematelemetry/schema_telemetry_event.go | 4 +- pkg/sql/catalog/tabledesc/validate_test.go | 6 +- pkg/sql/catalog/typedesc/type_desc_test.go | 8 +- pkg/sql/crdb_internal.go | 8 +- pkg/sql/doctor/doctor.go | 2 +- pkg/sql/schemachanger/scbackup/job.go | 2 +- .../schemachanger/scdeps/sctestdeps/config.go | 6 +- .../scdeps/sctestdeps/database_state.go | 4 +- .../scdeps/sctestdeps/test_deps.go | 10 +- .../scdeps/sctestdeps/test_state.go | 6 +- .../scexec/exec_backfill_test.go | 10 +- pkg/sql/schemachanger/sctest/decomp.go | 4 +- 32 files changed, 217 insertions(+), 176 deletions(-) diff --git a/pkg/ccl/backupccl/restore_job.go b/pkg/ccl/backupccl/restore_job.go index 7626a6925019..531d1f512d4e 100644 --- a/pkg/ccl/backupccl/restore_job.go +++ b/pkg/ccl/backupccl/restore_job.go @@ -2077,7 +2077,7 @@ func (r *restoreResumer) publishDescriptors( // Write the new TableDescriptors and flip state over to public so they can be // accessed. for i := range details.TableDescs { - mutTable := all.LookupDescriptorEntry(details.TableDescs[i].GetID()).(*tabledesc.Mutable) + mutTable := all.LookupDescriptor(details.TableDescs[i].GetID()).(*tabledesc.Mutable) // Note that we don't need to worry about the re-validated indexes for descriptors // with a declarative schema change job. if mutTable.GetDeclarativeSchemaChangerState() != nil { @@ -2132,7 +2132,7 @@ func (r *restoreResumer) publishDescriptors( // For all of the newly created types, make type schema change jobs for any // type descriptors that were backed up in the middle of a type schema change. for i := range details.TypeDescs { - typ := all.LookupDescriptorEntry(details.TypeDescs[i].GetID()).(catalog.TypeDescriptor) + typ := all.LookupDescriptor(details.TypeDescs[i].GetID()).(catalog.TypeDescriptor) newTypes = append(newTypes, typ.TypeDesc()) if typ.GetDeclarativeSchemaChangerState() == nil && typ.HasPendingSchemaChanges() { @@ -2144,19 +2144,19 @@ func (r *restoreResumer) publishDescriptors( } } for i := range details.SchemaDescs { - sc := all.LookupDescriptorEntry(details.SchemaDescs[i].GetID()).(catalog.SchemaDescriptor) + sc := all.LookupDescriptor(details.SchemaDescs[i].GetID()).(catalog.SchemaDescriptor) newSchemas = append(newSchemas, sc.SchemaDesc()) } for i := range details.DatabaseDescs { - db := all.LookupDescriptorEntry(details.DatabaseDescs[i].GetID()).(catalog.DatabaseDescriptor) + db := all.LookupDescriptor(details.DatabaseDescs[i].GetID()).(catalog.DatabaseDescriptor) newDBs = append(newDBs, db.DatabaseDesc()) } for i := range details.FunctionDescs { - fn := all.LookupDescriptorEntry(details.FunctionDescs[i].GetID()).(catalog.FunctionDescriptor) + fn := all.LookupDescriptor(details.FunctionDescs[i].GetID()).(catalog.FunctionDescriptor) newFunctions = append(newFunctions, fn.FuncDesc()) } b := txn.NewBatch() - if err := all.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + if err := all.ForEachDescriptor(func(desc catalog.Descriptor) error { d := desc.(catalog.MutableDescriptor) d.SetPublic() return descsCol.WriteDescToBatch( @@ -2250,7 +2250,7 @@ func prefetchDescriptors( got[i].GetID(), got[i].GetVersion(), expVersion[id], ) } - all.UpsertDescriptorEntry(got[i]) + all.UpsertDescriptor(got[i]) } return all.Catalog, nil } diff --git a/pkg/ccl/backupccl/restore_planning.go b/pkg/ccl/backupccl/restore_planning.go index d13220b3a864..c3d7e280f639 100644 --- a/pkg/ccl/backupccl/restore_planning.go +++ b/pkg/ccl/backupccl/restore_planning.go @@ -768,7 +768,7 @@ func maybeUpgradeDescriptors(descs []catalog.Descriptor, skipFKsWithNoMatchingTa // A data structure for efficient descriptor lookup by ID or by name. descCatalog := &nstree.MutableCatalog{} for _, d := range descs { - descCatalog.UpsertDescriptorEntry(d) + descCatalog.UpsertDescriptor(d) } for j, desc := range descs { @@ -781,7 +781,7 @@ func maybeUpgradeDescriptors(descs []catalog.Descriptor, skipFKsWithNoMatchingTa if err := b.RunPostDeserializationChanges(); err != nil { return errors.NewAssertionErrorWithWrappedErrf(err, "error during RunPostDeserializationChanges") } - err := b.RunRestoreChanges(descCatalog.LookupDescriptorEntry) + err := b.RunRestoreChanges(descCatalog.LookupDescriptor) if err != nil { return err } diff --git a/pkg/ccl/backupccl/show.go b/pkg/ccl/backupccl/show.go index 6fddcdfb3480..ddfd1343c2e9 100644 --- a/pkg/ccl/backupccl/show.go +++ b/pkg/ccl/backupccl/show.go @@ -704,7 +704,7 @@ func backupShowerDefault(p sql.PlanHookState, showSchemas bool, opts tree.KVOpti if len(hydratedDescriptors) == 0 { var c nstree.MutableCatalog for _, desc := range descriptors { - c.UpsertDescriptorEntry(desc) + c.UpsertDescriptor(desc) } if err := descs.HydrateCatalog(ctx, c); err != nil { return "", err diff --git a/pkg/sql/catalog/dbdesc/database_test.go b/pkg/sql/catalog/dbdesc/database_test.go index faa67a6dfea1..998c7262ab7c 100644 --- a/pkg/sql/catalog/dbdesc/database_test.go +++ b/pkg/sql/catalog/dbdesc/database_test.go @@ -267,14 +267,14 @@ func TestValidateCrossDatabaseReferences(t *testing.T) { var cb nstree.MutableCatalog test.desc.Privileges = privilege desc := NewBuilder(&test.desc).BuildImmutable() - cb.UpsertDescriptorEntry(desc) + cb.UpsertDescriptor(desc) test.multiRegionEnum.Privileges = privilege - cb.UpsertDescriptorEntry(typedesc.NewBuilder(&test.multiRegionEnum).BuildImmutable()) + cb.UpsertDescriptor(typedesc.NewBuilder(&test.multiRegionEnum).BuildImmutable()) for _, schemaDesc := range test.schemaDescs { schemaDesc.Privileges = privilege - cb.UpsertDescriptorEntry(schemadesc.NewBuilder(&schemaDesc).BuildImmutable()) + cb.UpsertDescriptor(schemadesc.NewBuilder(&schemaDesc).BuildImmutable()) } - _ = cb.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = cb.ForEachDescriptor(func(desc catalog.Descriptor) error { cb.UpsertNamespaceEntry(desc, desc.GetID(), desc.GetModificationTime()) return nil }) diff --git a/pkg/sql/catalog/descs/collection.go b/pkg/sql/catalog/descs/collection.go index 37c744b92e15..69ce7e8c700a 100644 --- a/pkg/sql/catalog/descs/collection.go +++ b/pkg/sql/catalog/descs/collection.go @@ -375,7 +375,7 @@ func (tc *Collection) DeleteNamespaceEntryToBatch( } func (tc *Collection) markAsShadowedName(id descpb.ID) { - desc := tc.cr.Cache().LookupDescriptorEntry(id) + desc := tc.cr.Cache().LookupDescriptor(id) if desc == nil { return } @@ -741,7 +741,7 @@ func (tc *Collection) GetAllDescriptorsForDatabase( var ret nstree.MutableCatalog var functionIDs catalog.DescriptorIDSet for _, desc := range descs { - ret.UpsertDescriptorEntry(desc) + ret.UpsertDescriptor(desc) if sc, ok := desc.(catalog.SchemaDescriptor); ok { _ = sc.ForEachFunctionOverload(func(overload descpb.SchemaDescriptor_FunctionOverload) error { functionIDs.Add(overload.ID) @@ -755,7 +755,7 @@ func (tc *Collection) GetAllDescriptorsForDatabase( return nstree.Catalog{}, err } for _, desc := range descs { - ret.UpsertDescriptorEntry(desc) + ret.UpsertDescriptor(desc) } return ret.Catalog, nil } @@ -767,7 +767,7 @@ func (tc *Collection) GetAllDescriptors(ctx context.Context, txn *kv.Txn) (nstre return nstree.Catalog{}, err } var ids catalog.DescriptorIDSet - _ = read.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = read.ForEachDescriptor(func(desc catalog.Descriptor) error { ids.Add(desc.GetID()) return nil }) @@ -793,7 +793,7 @@ func (tc *Collection) GetAllDescriptors(ctx context.Context, txn *kv.Txn) (nstre } var ret nstree.MutableCatalog for _, desc := range descs { - ret.UpsertDescriptorEntry(desc) + ret.UpsertDescriptor(desc) } return ret.Catalog, nil } @@ -821,7 +821,7 @@ func (tc *Collection) GetAllDatabaseDescriptors( return nil, err } var m nstree.NameMap - _ = read.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = read.ForEachDescriptor(func(desc catalog.Descriptor) error { m.Upsert(desc, desc.SkipNamespace()) return nil }) @@ -875,12 +875,12 @@ func (tc *Collection) GetAllTableDescriptorsInDatabase( return nil, err } // Ensure the given ID does indeed belong to a database. - if desc := all.LookupDescriptorEntry(db.GetID()); desc == nil || desc.DescriptorType() != catalog.Database { + if desc := all.LookupDescriptor(db.GetID()); desc == nil || desc.DescriptorType() != catalog.Database { return nil, sqlerrors.NewUndefinedDatabaseError(db.GetName()) } dbID := db.GetID() var ret []catalog.TableDescriptor - _ = all.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = all.ForEachDescriptor(func(desc catalog.Descriptor) error { if desc.GetParentID() != dbID { return nil } diff --git a/pkg/sql/catalog/descs/collection_test.go b/pkg/sql/catalog/descs/collection_test.go index 72a1b940b090..21cdaf1b3b58 100644 --- a/pkg/sql/catalog/descs/collection_test.go +++ b/pkg/sql/catalog/descs/collection_test.go @@ -727,7 +727,7 @@ func TestDescriptorCache(t *testing.T) { if err != nil { return err } - found := cat.LookupDescriptorEntry(mut.ID) + found := cat.LookupDescriptor(mut.ID) require.NotEmpty(t, found) require.Equal(t, mut.ImmutableCopy().DescriptorProto(), found.DescriptorProto()) return nil @@ -999,21 +999,21 @@ func TestHydrateCatalog(t *testing.T) { deleteDescriptor := func(name string) catalogTamperFn { return func(cat nstree.Catalog) nstree.Catalog { var descToDelete catid.DescID - _ = cat.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = cat.ForEachDescriptor(func(desc catalog.Descriptor) error { if desc.GetName() == name { descToDelete = desc.GetID() } return nil }) mutCat := nstree.MutableCatalog{Catalog: cat} - mutCat.DeleteDescriptorEntry(descToDelete) + mutCat.DeleteByID(descToDelete) return mutCat.Catalog } } replaceTypeDescWithNonTypeDesc := func(name string) catalogTamperFn { return func(cat nstree.Catalog) nstree.Catalog { var typeDescID catid.DescID - _ = cat.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = cat.ForEachDescriptor(func(desc catalog.Descriptor) error { if desc.GetName() == name { typeDescID = desc.GetID() } @@ -1022,7 +1022,7 @@ func TestHydrateCatalog(t *testing.T) { // Make a dummy database descriptor to replace the type descriptor. dbDesc := dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ID: typeDescID}).BuildImmutable() mutCat := nstree.MutableCatalog{Catalog: cat} - mutCat.UpsertDescriptorEntry(dbDesc) + mutCat.UpsertDescriptor(dbDesc) return mutCat.Catalog } } @@ -1064,7 +1064,7 @@ func TestHydrateCatalog(t *testing.T) { mc := nstree.MutableCatalog{Catalog: cat} require.NoError(t, descs.HydrateCatalog(ctx, mc)) tbl := desctestutils.TestingGetTableDescriptor(txn.DB(), keys.SystemSQLCodec, "db", "schema", "table") - tblDesc := cat.LookupDescriptorEntry(tbl.GetID()).(catalog.TableDescriptor) + tblDesc := cat.LookupDescriptor(tbl.GetID()).(catalog.TableDescriptor) expectedEnum := types.UserDefinedTypeMetadata{ Name: &types.UserDefinedTypeName{ Catalog: "db", @@ -1152,7 +1152,7 @@ SELECT id if err != nil { return err } - require.Equal(t, tabImm, all.LookupDescriptorEntry(tabImm.GetID())) + require.Equal(t, tabImm, all.LookupDescriptor(tabImm.GetID())) return nil } diff --git a/pkg/sql/catalog/descs/descriptor.go b/pkg/sql/catalog/descs/descriptor.go index 6732a68096c3..fd42c26bc777 100644 --- a/pkg/sql/catalog/descs/descriptor.go +++ b/pkg/sql/catalog/descs/descriptor.go @@ -112,7 +112,7 @@ func (tc *Collection) GetComment(key catalogkeys.CommentKey) (string, bool) { return cmt, hasCmt } if tc.cr.IsIDInCache(descpb.ID(key.ObjectID)) { - return tc.cr.Cache().LookupCommentEntry(key) + return tc.cr.Cache().LookupComment(key) } // TODO(chengxiong): we need to ensure descriptor if it's not in either cache // and it's not a pseudo descriptor. @@ -162,7 +162,7 @@ func (tc *Collection) GetZoneConfigs( if err != nil { return nil, err } - _ = read.ForEachZoneConfigEntry(func(id descpb.ID, zc catalog.ZoneConfig) error { + _ = read.ForEachZoneConfig(func(id descpb.ID, zc catalog.ZoneConfig) error { ret[id] = zc.Clone() return nil }) @@ -329,7 +329,7 @@ func getDescriptorsByID( } for i, id := range ids { if descs[i] == nil { - descs[i] = read.LookupDescriptorEntry(id) + descs[i] = read.LookupDescriptor(id) vls[i] = tc.validationLevels[id] } } @@ -412,7 +412,7 @@ func (q *byIDLookupContext) lookupCached( id descpb.ID, ) (catalog.Descriptor, catalog.ValidationLevel, error) { if q.tc.cr.IsIDInCache(id) { - if desc := q.tc.cr.Cache().LookupDescriptorEntry(id); desc != nil { + if desc := q.tc.cr.Cache().LookupDescriptor(id); desc != nil { return desc, q.tc.validationLevels[id], nil } } diff --git a/pkg/sql/catalog/descs/hydrate.go b/pkg/sql/catalog/descs/hydrate.go index e8b72190994d..1fd4e9617f4f 100644 --- a/pkg/sql/catalog/descs/hydrate.go +++ b/pkg/sql/catalog/descs/hydrate.go @@ -118,7 +118,7 @@ func makeMutableTypeLookupFunc( if _, ok := desc.(catalog.MutableDescriptor); !ok { continue } - mut.UpsertDescriptorEntry(desc) + mut.UpsertDescriptor(desc) } mutableLookupFunc := func(ctx context.Context, id descpb.ID) (catalog.Descriptor, error) { // This special case exists to deal with the desire to use enums in the @@ -150,7 +150,7 @@ func makeImmutableTypeLookupFunc( if _, ok := desc.(catalog.MutableDescriptor); ok { continue } - imm.UpsertDescriptorEntry(desc) + imm.UpsertDescriptor(desc) } immutableLookupFunc := func(ctx context.Context, id descpb.ID) (catalog.Descriptor, error) { return tc.GetImmutableDescriptorByID(ctx, txn, id, tree.CommonLookupFlags{ @@ -173,7 +173,7 @@ func HydrateCatalog(ctx context.Context, c nstree.MutableCatalog) error { return nil, catalog.WrapDescRefErr(id, catalog.ErrDescriptorNotFound) } typeLookupFunc := hydrateddesc.MakeTypeLookupFuncForHydration(c.Catalog, fakeLookupFunc) - return c.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + return c.ForEachDescriptor(func(desc catalog.Descriptor) error { if !hydrateddesc.IsHydratable(desc) { return nil } @@ -182,7 +182,7 @@ func HydrateCatalog(ctx context.Context, c nstree.MutableCatalog) error { } // Deep-copy the immutable descriptor and overwrite the catalog entry. desc = desc.NewBuilder().BuildImmutable() - defer c.UpsertDescriptorEntry(desc) + defer c.UpsertDescriptor(desc) return hydrateddesc.Hydrate(ctx, desc, typeLookupFunc) }) } diff --git a/pkg/sql/catalog/funcdesc/func_desc_test.go b/pkg/sql/catalog/funcdesc/func_desc_test.go index 6811c3650ab9..685467d03985 100644 --- a/pkg/sql/catalog/funcdesc/func_desc_test.go +++ b/pkg/sql/catalog/funcdesc/func_desc_test.go @@ -55,24 +55,24 @@ func TestValidateFuncDesc(t *testing.T) { funcDescID := descpb.ID(bootstrap.TestingUserDescID(0)) var cb nstree.MutableCatalog - cb.UpsertDescriptorEntry(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ + cb.UpsertDescriptor(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ Name: "db", ID: dbID, }).BuildImmutable()) - cb.UpsertDescriptorEntry(schemadesc.NewBuilder(&descpb.SchemaDescriptor{ + cb.UpsertDescriptor(schemadesc.NewBuilder(&descpb.SchemaDescriptor{ ID: schemaID, ParentID: dbID, Name: "schema", }).BuildImmutable()) - cb.UpsertDescriptorEntry(typedesc.NewBuilder(&descpb.TypeDescriptor{ + cb.UpsertDescriptor(typedesc.NewBuilder(&descpb.TypeDescriptor{ ID: typeID, Name: "type", }).BuildImmutable()) - cb.UpsertDescriptorEntry(tabledesc.NewBuilder(&descpb.TableDescriptor{ + cb.UpsertDescriptor(tabledesc.NewBuilder(&descpb.TableDescriptor{ ID: tableID, Name: "tbl", }).BuildImmutable()) - cb.UpsertDescriptorEntry(schemadesc.NewBuilder(&descpb.SchemaDescriptor{ + cb.UpsertDescriptor(schemadesc.NewBuilder(&descpb.SchemaDescriptor{ ID: schemaWithFuncRefID, ParentID: dbID, Name: "schema", @@ -80,17 +80,17 @@ func TestValidateFuncDesc(t *testing.T) { "f": {Overloads: []descpb.SchemaDescriptor_FunctionOverload{{ID: funcDescID}}}, }, }).BuildImmutable()) - cb.UpsertDescriptorEntry(typedesc.NewBuilder(&descpb.TypeDescriptor{ + cb.UpsertDescriptor(typedesc.NewBuilder(&descpb.TypeDescriptor{ ID: typeWithFuncRefID, Name: "type", ReferencingDescriptorIDs: []descpb.ID{funcDescID}, }).BuildImmutable()) - cb.UpsertDescriptorEntry(tabledesc.NewBuilder(&descpb.TableDescriptor{ + cb.UpsertDescriptor(tabledesc.NewBuilder(&descpb.TableDescriptor{ ID: tableWithFuncBackRefID, Name: "tbl", DependedOnBy: []descpb.TableDescriptor_Reference{{ID: funcDescID}}, }).BuildImmutable()) - cb.UpsertDescriptorEntry(tabledesc.NewBuilder(&descpb.TableDescriptor{ + cb.UpsertDescriptor(tabledesc.NewBuilder(&descpb.TableDescriptor{ ID: tableWithFuncForwardRefID, Name: "tbl", DependsOn: []descpb.ID{funcDescID}, diff --git a/pkg/sql/catalog/hydrateddesc/hydrate.go b/pkg/sql/catalog/hydrateddesc/hydrate.go index 64be5bcc323e..fed03d27fb2c 100644 --- a/pkg/sql/catalog/hydrateddesc/hydrate.go +++ b/pkg/sql/catalog/hydrateddesc/hydrate.go @@ -67,7 +67,7 @@ func MakeTypeLookupFuncForHydration( c nstree.Catalog, lookupFn HydrationLookupFunc, ) typedesc.TypeLookupFunc { return func(ctx context.Context, id descpb.ID) (tn tree.TypeName, typ catalog.TypeDescriptor, err error) { - typDesc := c.LookupDescriptorEntry(id) + typDesc := c.LookupDescriptor(id) if typDesc == nil { typDesc, err = lookupFn(ctx, id) if err != nil { @@ -89,7 +89,7 @@ func MakeTypeLookupFuncForHydration( if err != nil { return tree.TypeName{}, nil, err } - dbDesc := c.LookupDescriptorEntry(typ.GetParentID()) + dbDesc := c.LookupDescriptor(typ.GetParentID()) if dbDesc == nil { dbDesc, err = lookupFn(ctx, typ.GetParentID()) if err != nil { @@ -103,7 +103,7 @@ func MakeTypeLookupFuncForHydration( if _, err = catalog.AsDatabaseDescriptor(dbDesc); err != nil { return tree.TypeName{}, nil, err } - scDesc := c.LookupDescriptorEntry(typ.GetParentSchemaID()) + scDesc := c.LookupDescriptor(typ.GetParentSchemaID()) if scDesc == nil { scDesc, err = lookupFn(ctx, typ.GetParentSchemaID()) if err != nil { diff --git a/pkg/sql/catalog/hydrateddesc/hydratedcache_test.go b/pkg/sql/catalog/hydrateddesc/hydratedcache_test.go index 19231cf51f69..75a99b68fae8 100644 --- a/pkg/sql/catalog/hydrateddesc/hydratedcache_test.go +++ b/pkg/sql/catalog/hydrateddesc/hydratedcache_test.go @@ -77,10 +77,10 @@ func TestHydratedCache(t *testing.T) { assertMetrics(t, m, 0, 1, catalog.Table) // Change the database name. - dbDesc := dbdesc.NewBuilder(dg.LookupDescriptorEntry(dbID).(catalog.DatabaseDescriptor).DatabaseDesc()).BuildExistingMutableDatabase() + dbDesc := dbdesc.NewBuilder(dg.LookupDescriptor(dbID).(catalog.DatabaseDescriptor).DatabaseDesc()).BuildExistingMutableDatabase() dbDesc.SetName("new_name") dbDesc.Version++ - dg.UpsertDescriptorEntry(dbDesc.ImmutableCopy()) + dg.UpsertDescriptor(dbDesc.ImmutableCopy()) // Ensure that we observe a new descriptor get created due to // the name change. @@ -136,9 +136,9 @@ func TestHydratedCache(t *testing.T) { assertMetrics(t, m, 0, 1, catalog.Table) // Change the type descriptor. - typDesc := typedesc.NewBuilder(dg.LookupDescriptorEntry(typ1ID).(catalog.TypeDescriptor).TypeDesc()).BuildExistingMutableType() + typDesc := typedesc.NewBuilder(dg.LookupDescriptor(typ1ID).(catalog.TypeDescriptor).TypeDesc()).BuildExistingMutableType() typDesc.Version++ - dg.UpsertDescriptorEntry(typedesc.NewBuilder(typDesc.TypeDesc()).BuildImmutable()) + dg.UpsertDescriptor(typedesc.NewBuilder(typDesc.TypeDesc()).BuildImmutable()) // Ensure that a new descriptor is returned. retrieved, err := c.GetHydratedTableDescriptor(ctx, td, res) @@ -180,7 +180,7 @@ func TestHydratedCache(t *testing.T) { }) t.Run("modified table gets rejected", func(t *testing.T) { c, _, dg, res := makeCache() - mut := tabledesc.NewBuilder(dg.LookupDescriptorEntry(tableUDTID).(catalog.TableDescriptor).TableDesc()).BuildExistingMutable() + mut := tabledesc.NewBuilder(dg.LookupDescriptor(tableUDTID).(catalog.TableDescriptor).TableDesc()).BuildExistingMutable() mut.MaybeIncrementVersion() td := mut.ImmutableCopy().(catalog.TableDescriptor) hydrated, err := c.GetHydratedTableDescriptor(ctx, td, res) @@ -190,7 +190,7 @@ func TestHydratedCache(t *testing.T) { t.Run("modified type does not get cached", func(t *testing.T) { c, m, dg, res := makeCache() - mut := typedesc.NewBuilder(dg.LookupDescriptorEntry(typ1ID).(catalog.TypeDescriptor).TypeDesc()).BuildExistingMutable() + mut := typedesc.NewBuilder(dg.LookupDescriptor(typ1ID).(catalog.TypeDescriptor).TypeDesc()).BuildExistingMutable() mut.MaybeIncrementVersion() dgWithMut := mkDescGetter(append(descs, mut)...) resWithMut := &descGetterTypeDescriptorResolver{dg: &dgWithMut} @@ -463,7 +463,7 @@ var ( func mkDescGetter(descs ...catalog.MutableDescriptor) (cb nstree.MutableCatalog) { for _, desc := range descs { - cb.UpsertDescriptorEntry(desc.ImmutableCopy()) + cb.UpsertDescriptor(desc.ImmutableCopy()) } return cb } @@ -484,15 +484,15 @@ func (d *descGetterTypeDescriptorResolver) GetTypeDescriptor( return tree.TypeName{}, nil, err } } - desc := d.dg.LookupDescriptorEntry(id) + desc := d.dg.LookupDescriptor(id) if d.unqualifiedName { return tree.MakeUnqualifiedTypeName(desc.GetName()), desc.(catalog.TypeDescriptor), nil } - dbDesc := d.dg.LookupDescriptorEntry(desc.GetParentID()) + dbDesc := d.dg.LookupDescriptor(desc.GetParentID()) // Assume we've got a user-defined schema. // TODO(ajwerner): Unify this with some other resolution logic. - scDesc := d.dg.LookupDescriptorEntry(desc.GetParentSchemaID()) + scDesc := d.dg.LookupDescriptor(desc.GetParentSchemaID()) name := tree.MakeQualifiedTypeName(dbDesc.GetName(), scDesc.GetName(), desc.GetName()) return name, desc.(catalog.TypeDescriptor), nil } diff --git a/pkg/sql/catalog/internal/catkv/catalog_query.go b/pkg/sql/catalog/internal/catkv/catalog_query.go index 1e57b7fd7e56..9a4efd0324e3 100644 --- a/pkg/sql/catalog/internal/catkv/catalog_query.go +++ b/pkg/sql/catalog/internal/catkv/catalog_query.go @@ -115,7 +115,7 @@ func (cq catalogQuery) processDescriptorResultRow( if err != nil { return wrapError(expectedType, id, err) } - cb.UpsertDescriptorEntry(desc) + cb.UpsertDescriptor(desc) return nil } diff --git a/pkg/sql/catalog/internal/catkv/catalog_reader.go b/pkg/sql/catalog/internal/catkv/catalog_reader.go index 12f5d81f63df..ae6f53a52522 100644 --- a/pkg/sql/catalog/internal/catkv/catalog_reader.go +++ b/pkg/sql/catalog/internal/catkv/catalog_reader.go @@ -242,7 +242,7 @@ func (cr catalogReader) GetByIDs( } if isDescriptorRequired { for _, id := range ids { - if mc.LookupDescriptorEntry(id) == nil { + if mc.LookupDescriptor(id) == nil { return nstree.Catalog{}, wrapError(expectedType, id, requiredError(expectedType, id)) } } diff --git a/pkg/sql/catalog/internal/catkv/catalog_reader_cached.go b/pkg/sql/catalog/internal/catkv/catalog_reader_cached.go index 61ae3b50fe34..0f4e0e2b0d4b 100644 --- a/pkg/sql/catalog/internal/catkv/catalog_reader_cached.go +++ b/pkg/sql/catalog/internal/catkv/catalog_reader_cached.go @@ -113,7 +113,7 @@ func (c *cachedCatalogReader) IsNameInCache(key catalog.NameKey) bool { // IsDescIDKnownToNotExist is part of the CatalogReader interface. func (c *cachedCatalogReader) IsDescIDKnownToNotExist(id, maybeParentID descpb.ID) bool { - if c.cache.LookupDescriptorEntry(id) != nil { + if c.cache.LookupDescriptor(id) != nil { return false } if c.hasScanAll { @@ -303,7 +303,7 @@ func (c *cachedCatalogReader) GetByIDs( continue } if desc := c.systemDatabaseCache.lookupDescriptor(c.version, id); desc != nil { - c.cache.UpsertDescriptorEntry(desc) + c.cache.UpsertDescriptor(desc) } ids[i], ids[numUncached] = ids[numUncached], id numUncached++ @@ -323,10 +323,10 @@ func (c *cachedCatalogReader) GetByIDs( c.setByIDState(id, s) } } - ret := c.cache.FilterByIDs(ids) + ret := c.cache.FilterByIDsExclusive(ids) if isDescriptorRequired { for _, id := range ids[numUncached:] { - if ret.LookupDescriptorEntry(id) == nil { + if ret.LookupDescriptor(id) == nil { return nstree.Catalog{}, wrapError(expectedType, id, requiredError(expectedType, id)) } } @@ -378,7 +378,7 @@ func (c *cachedCatalogReader) ensure(ctx context.Context, read nstree.Catalog) e oldSize := c.cache.ByteSize() c.cache.AddAll(read) c.systemDatabaseCache.update(c.version, read) - _ = read.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = read.ForEachDescriptor(func(desc catalog.Descriptor) error { if desc.Dropped() { return nil } diff --git a/pkg/sql/catalog/internal/catkv/catalog_reader_test.go b/pkg/sql/catalog/internal/catkv/catalog_reader_test.go index c3c58d1c9e3d..8fb11316d2fa 100644 --- a/pkg/sql/catalog/internal/catkv/catalog_reader_test.go +++ b/pkg/sql/catalog/internal/catkv/catalog_reader_test.go @@ -213,7 +213,7 @@ func (h testHelper) argDesc( }) require.NoErrorf(h.t, err, "%s: error reading %s descriptor %d", h.d.Pos, expectedType, id) - desc := c.LookupDescriptorEntry(id) + desc := c.LookupDescriptor(id) require.NotNilf(h.t, desc, "%s: nil %s descriptor %d", h.d.Pos, expectedType, id) require.Equal(h.t, expectedType, desc.DescriptorType(), @@ -305,7 +305,7 @@ func (h testHelper) catalogToYaml(c nstree.Catalog) interface{} { m[ns.GetID()] = j return nil }) - _ = c.ForEachDescriptorEntry(func(d catalog.Descriptor) error { + _ = c.ForEachDescriptor(func(d catalog.Descriptor) error { mut := d.NewBuilder().BuildCreatedMutable() mut.ResetModificationTime() j := m[d.GetID()] @@ -313,13 +313,13 @@ func (h testHelper) catalogToYaml(c nstree.Catalog) interface{} { m[d.GetID()] = j return nil }) - _ = c.ForEachZoneConfigEntry(func(id descpb.ID, zc catalog.ZoneConfig) error { + _ = c.ForEachZoneConfig(func(id descpb.ID, zc catalog.ZoneConfig) error { j := m[id] j.zc = zc m[id] = j return nil }) - _ = c.ForEachCommentEntry(func(key catalogkeys.CommentKey, cmt string) error { + _ = c.ForEachComment(func(key catalogkeys.CommentKey, cmt string) error { id := descpb.ID(key.ObjectID) j := m[id] j.comments = append(j.comments, struct { diff --git a/pkg/sql/catalog/internal/catkv/direct.go b/pkg/sql/catalog/internal/catkv/direct.go index 9bad4c384f0e..56059ce3eb43 100644 --- a/pkg/sql/catalog/internal/catkv/direct.go +++ b/pkg/sql/catalog/internal/catkv/direct.go @@ -224,7 +224,7 @@ func (d *direct) readDescriptorsForDirectAccess( } descs := make([]catalog.Descriptor, len(ids)) for i, id := range ids { - desc := c.LookupDescriptorEntry(id) + desc := c.LookupDescriptor(id) if desc == nil { continue } diff --git a/pkg/sql/catalog/internal/catkv/validate.go b/pkg/sql/catalog/internal/catkv/validate.go index de35dd681413..ba07374ca0c0 100644 --- a/pkg/sql/catalog/internal/catkv/validate.go +++ b/pkg/sql/catalog/internal/catkv/validate.go @@ -65,7 +65,7 @@ func (c catalogReaderBackedDereferencer) DereferenceDescriptors( } ret := make([]catalog.Descriptor, len(reqs)) for i, id := range reqs { - desc := read.LookupDescriptorEntry(id) + desc := read.LookupDescriptor(id) if desc == nil { continue } diff --git a/pkg/sql/catalog/nstree/catalog.go b/pkg/sql/catalog/nstree/catalog.go index 993d97d759e0..459efadae6e4 100644 --- a/pkg/sql/catalog/nstree/catalog.go +++ b/pkg/sql/catalog/nstree/catalog.go @@ -31,9 +31,9 @@ type Catalog struct { byteSize int64 } -// ForEachDescriptorEntry iterates over all descriptor table entries in an +// ForEachDescriptor iterates over all descriptor table entries in an // ordered fashion. -func (c Catalog) ForEachDescriptorEntry(fn func(desc catalog.Descriptor) error) error { +func (c Catalog) ForEachDescriptor(fn func(desc catalog.Descriptor) error) error { if !c.IsInitialized() { return nil } @@ -45,9 +45,9 @@ func (c Catalog) ForEachDescriptorEntry(fn func(desc catalog.Descriptor) error) }) } -// ForEachCommentEntry iterates through all descriptor comments in the same +// ForEachComment iterates through all descriptor comments in the same // order as in system.comments. -func (c Catalog) ForEachCommentEntry(fn func(key catalogkeys.CommentKey, cmt string) error) error { +func (c Catalog) ForEachComment(fn func(key catalogkeys.CommentKey, cmt string) error) error { if !c.IsInitialized() { return nil } @@ -56,9 +56,24 @@ func (c Catalog) ForEachCommentEntry(fn func(key catalogkeys.CommentKey, cmt str }) } -// ForEachZoneConfigEntry iterates over all zone config table entries in an +// ForEachCommentOnDescriptor iterates through all comments on a specific +// descriptor in the same order as in system.comments. +func (c Catalog) ForEachCommentOnDescriptor( + id descpb.ID, fn func(key catalogkeys.CommentKey, cmt string) error, +) error { + if !c.IsInitialized() { + return nil + } + e := c.byID.get(id) + if e == nil { + return nil + } + return e.(*byIDEntry).forEachComment(fn) +} + +// ForEachZoneConfig iterates over all zone config table entries in an // ordered fashion. -func (c Catalog) ForEachZoneConfigEntry(fn func(id descpb.ID, zc catalog.ZoneConfig) error) error { +func (c Catalog) ForEachZoneConfig(fn func(id descpb.ID, zc catalog.ZoneConfig) error) error { if !c.IsInitialized() { return nil } @@ -106,8 +121,8 @@ func (c Catalog) ForEachSchemaNamespaceEntryInDatabase( }) } -// LookupDescriptorEntry looks up a descriptor by ID. -func (c Catalog) LookupDescriptorEntry(id descpb.ID) catalog.Descriptor { +// LookupDescriptor looks up a descriptor by ID. +func (c Catalog) LookupDescriptor(id descpb.ID) catalog.Descriptor { if !c.IsInitialized() || id == descpb.InvalidID { return nil } @@ -118,8 +133,8 @@ func (c Catalog) LookupDescriptorEntry(id descpb.ID) catalog.Descriptor { return e.(*byIDEntry).desc } -// LookupCommentEntry looks up a comment by (CommentType, ID, SubID). -func (c Catalog) LookupCommentEntry(key catalogkeys.CommentKey) (_ string, found bool) { +// LookupComment looks up a comment by (CommentType, ID, SubID). +func (c Catalog) LookupComment(key catalogkeys.CommentKey) (_ string, found bool) { if !c.IsInitialized() { return "", false } @@ -135,8 +150,8 @@ func (c Catalog) LookupCommentEntry(key catalogkeys.CommentKey) (_ string, found return cbt.comments[ordinal], true } -// LookupZoneConfigEntry looks up a zone config by ID. -func (c Catalog) LookupZoneConfigEntry(id descpb.ID) catalog.ZoneConfig { +// LookupZoneConfig looks up a zone config by ID. +func (c Catalog) LookupZoneConfig(id descpb.ID) catalog.ZoneConfig { if !c.IsInitialized() { return nil } @@ -165,7 +180,7 @@ func (c Catalog) OrderedDescriptors() []catalog.Descriptor { return nil } ret := make([]catalog.Descriptor, 0, c.byID.t.Len()) - _ = c.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = c.ForEachDescriptor(func(desc catalog.Descriptor) error { ret = append(ret, desc) return nil }) @@ -200,7 +215,7 @@ func (c Catalog) DereferenceDescriptors( ) ([]catalog.Descriptor, error) { ret := make([]catalog.Descriptor, len(reqs)) for i, id := range reqs { - ret[i] = c.LookupDescriptorEntry(id) + ret[i] = c.LookupDescriptor(id) } return ret, nil } @@ -254,7 +269,7 @@ func (c Catalog) ValidateNamespaceEntry(key catalog.NameKey) error { } } // Compare the namespace entry with the referenced descriptor. - desc := c.LookupDescriptorEntry(ne.GetID()) + desc := c.LookupDescriptor(ne.GetID()) if desc == nil { return catalog.ErrDescriptorNotFound } @@ -294,3 +309,63 @@ func (c Catalog) ValidateWithRecover( func (c Catalog) ByteSize() int64 { return c.byteSize } + +// FilterByIDs returns a subset of the catalog only for the desired IDs. +func (c Catalog) FilterByIDs(ids []descpb.ID) Catalog { + var ret MutableCatalog + ret.addByIDEntries(c, ids) + if !ret.IsInitialized() { + return Catalog{} + } + _ = c.byName.ascend(func(found catalog.NameEntry) error { + if ret.byID.get(found.GetID()) == nil { + return nil + } + e := ret.ensureForName(found) + *e = *found.(*byNameEntry) + return nil + }) + return ret.Catalog +} + +// FilterByIDsExclusive is like FilterByIDs but without any by-name entries. +func (c Catalog) FilterByIDsExclusive(ids []descpb.ID) Catalog { + var ret MutableCatalog + ret.addByIDEntries(c, ids) + return ret.Catalog +} + +func (mc *MutableCatalog) addByIDEntries(c Catalog, ids []descpb.ID) { + if !c.IsInitialized() { + return + } + for _, id := range ids { + found := c.byID.get(id) + if found == nil { + continue + } + e := mc.ensureForID(id) + *e = *found.(*byIDEntry) + } +} + +// FilterByNames returns a subset of the catalog only for the desired names. +func (c Catalog) FilterByNames(nameInfos []descpb.NameInfo) Catalog { + if !c.IsInitialized() { + return Catalog{} + } + var ret MutableCatalog + for _, ni := range nameInfos { + found := c.byName.getByName(ni.ParentID, ni.ParentSchemaID, ni.Name) + if found == nil { + continue + } + e := ret.ensureForName(&ni) + *e = *found.(*byNameEntry) + if foundByID := c.byID.get(e.id); foundByID != nil { + e := ret.ensureForID(e.id) + *e = *foundByID.(*byIDEntry) + } + } + return ret.Catalog +} diff --git a/pkg/sql/catalog/nstree/catalog_mutable.go b/pkg/sql/catalog/nstree/catalog_mutable.go index ac084518b2a6..e6f809443990 100644 --- a/pkg/sql/catalog/nstree/catalog_mutable.go +++ b/pkg/sql/catalog/nstree/catalog_mutable.go @@ -72,23 +72,12 @@ func (mc *MutableCatalog) ensureForName(key catalog.NameKey) *byNameEntry { return newEntry } -// UpsertDescriptorEntry adds a descriptor to the MutableCatalog. -func (mc *MutableCatalog) UpsertDescriptorEntry(desc catalog.Descriptor) { - if desc == nil || desc.GetID() == descpb.InvalidID { - return - } - e := mc.ensureForID(desc.GetID()) - mc.byteSize -= e.ByteSize() - e.desc = desc - mc.byteSize += e.ByteSize() -} - -// DeleteDescriptorEntry removes a descriptor from the MutableCatalog. -func (mc *MutableCatalog) DeleteDescriptorEntry(id descpb.ID) { - if id == descpb.InvalidID || !mc.IsInitialized() { +// DeleteByName removes all by-name mappings from the MutableCatalog. +func (mc *MutableCatalog) DeleteByName(key catalog.NameKey) { + if key == nil || !mc.IsInitialized() { return } - if removed := mc.byID.delete(id); removed != nil { + if removed := mc.byName.delete(key); removed != nil { mc.byteSize -= removed.(catalogEntry).ByteSize() } } @@ -105,16 +94,27 @@ func (mc *MutableCatalog) UpsertNamespaceEntry( e.timestamp = mvccTimestamp } -// DeleteNamespaceEntry removes a name -> id mapping from the MutableCatalog. -func (mc *MutableCatalog) DeleteNamespaceEntry(key catalog.NameKey) { - if key == nil || !mc.IsInitialized() { +// DeleteByID removes all by-ID mappings from the MutableCatalog. +func (mc *MutableCatalog) DeleteByID(id descpb.ID) { + if !mc.IsInitialized() { return } - if removed := mc.byName.delete(key); removed != nil { + if removed := mc.byID.delete(id); removed != nil { mc.byteSize -= removed.(catalogEntry).ByteSize() } } +// UpsertDescriptor adds a descriptor to the MutableCatalog. +func (mc *MutableCatalog) UpsertDescriptor(desc catalog.Descriptor) { + if desc == nil || desc.GetID() == descpb.InvalidID { + return + } + e := mc.ensureForID(desc.GetID()) + mc.byteSize -= e.ByteSize() + e.desc = desc + mc.byteSize += e.ByteSize() +} + // UpsertComment upserts a ((ObjectID, SubID, CommentType) -> Comment) mapping // into the catalog. func (mc *MutableCatalog) UpsertComment(key catalogkeys.CommentKey, cmt string) { @@ -141,40 +141,6 @@ func (mc *MutableCatalog) UpsertZoneConfig( mc.byteSize += e.ByteSize() } -// FilterByIDs returns a subset of the catalog only for the desired IDs. -func (mc *MutableCatalog) FilterByIDs(ids []descpb.ID) Catalog { - if !mc.IsInitialized() { - return Catalog{} - } - var ret MutableCatalog - for _, id := range ids { - found := mc.byID.get(id) - if found == nil { - continue - } - e := ret.ensureForID(id) - *e = *found.(*byIDEntry) - } - return ret.Catalog -} - -// FilterByNames returns a subset of the catalog only for the desired names. -func (mc *MutableCatalog) FilterByNames(nameInfos []descpb.NameInfo) Catalog { - if !mc.IsInitialized() { - return Catalog{} - } - var ret MutableCatalog - for _, ni := range nameInfos { - found := mc.byName.getByName(ni.ParentID, ni.ParentSchemaID, ni.Name) - if found == nil { - continue - } - e := ret.ensureForName(&ni) - *e = *found.(*byNameEntry) - } - return ret.Catalog -} - // AddAll adds the contents of the provided catalog to this one. func (mc *MutableCatalog) AddAll(c Catalog) { if !c.IsInitialized() { diff --git a/pkg/sql/catalog/schemadesc/schema_desc_test.go b/pkg/sql/catalog/schemadesc/schema_desc_test.go index 8e6f82b75cd9..b23aaf906745 100644 --- a/pkg/sql/catalog/schemadesc/schema_desc_test.go +++ b/pkg/sql/catalog/schemadesc/schema_desc_test.go @@ -228,9 +228,9 @@ func TestValidateCrossSchemaReferences(t *testing.T) { var cb nstree.MutableCatalog test.desc.Privileges = privilege desc := schemadesc.NewBuilder(&test.desc).BuildImmutable() - cb.UpsertDescriptorEntry(desc) + cb.UpsertDescriptor(desc) test.dbDesc.Privileges = privilege - cb.UpsertDescriptorEntry(dbdesc.NewBuilder(&test.dbDesc).BuildImmutable()) + cb.UpsertDescriptor(dbdesc.NewBuilder(&test.dbDesc).BuildImmutable()) expectedErr := fmt.Sprintf("%s %q (%d): %s", desc.DescriptorType(), desc.GetName(), desc.GetID(), test.err) const validateCrossReferencesOnly = catalog.ValidationLevelBackReferences &^ catalog.ValidationLevelSelfOnly results := cb.Validate(ctx, clusterversion.TestingClusterVersion, catalog.NoValidationTelemetry, validateCrossReferencesOnly, desc) diff --git a/pkg/sql/catalog/schematelemetry/schema_telemetry_event.go b/pkg/sql/catalog/schematelemetry/schema_telemetry_event.go index c4ff5faec88b..df99ad41d1a0 100644 --- a/pkg/sql/catalog/schematelemetry/schema_telemetry_event.go +++ b/pkg/sql/catalog/schematelemetry/schema_telemetry_event.go @@ -80,7 +80,7 @@ func CollectClusterSchemaForTelemetry( } // Redact the descriptors. redacted := make(map[descpb.ID]*eventpb.SchemaDescriptor, descIDsInSnapshot.Len()) - _ = raw.ForEachDescriptorEntry(func(rd catalog.Descriptor) error { + _ = raw.ForEachDescriptor(func(rd catalog.Descriptor) error { if !descIDsInSnapshot.Contains(rd.GetID()) { return nil } @@ -146,7 +146,7 @@ func truncatedCatalogKeys( }) return nil }) - _ = raw.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = raw.ForEachDescriptor(func(desc catalog.Descriptor) error { if !idsInNamespace.Contains(desc.GetID()) { keys = append(keys, joinedRecordKey{id: desc.GetID()}) } diff --git a/pkg/sql/catalog/tabledesc/validate_test.go b/pkg/sql/catalog/tabledesc/validate_test.go index 3ea670423d01..581c9f7a3764 100644 --- a/pkg/sql/catalog/tabledesc/validate_test.go +++ b/pkg/sql/catalog/tabledesc/validate_test.go @@ -2864,13 +2864,13 @@ func TestValidateCrossTableReferences(t *testing.T) { for i, test := range tests { t.Run(test.err, func(t *testing.T) { var cb nstree.MutableCatalog - cb.UpsertDescriptorEntry(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ID: 1}).BuildImmutable()) + cb.UpsertDescriptor(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ID: 1}).BuildImmutable()) for _, otherDesc := range test.otherDescs { otherDesc.Privileges = catpb.NewBasePrivilegeDescriptor(username.AdminRoleName()) - cb.UpsertDescriptorEntry(NewBuilder(&otherDesc).BuildImmutable()) + cb.UpsertDescriptor(NewBuilder(&otherDesc).BuildImmutable()) } desc := NewBuilder(&test.desc).BuildImmutable() - cb.UpsertDescriptorEntry(funcdesc.NewBuilder(&descpb.FunctionDescriptor{ID: 100, Name: "f"}).BuildImmutable()) + cb.UpsertDescriptor(funcdesc.NewBuilder(&descpb.FunctionDescriptor{ID: 100, Name: "f"}).BuildImmutable()) expectedErr := fmt.Sprintf("%s %q (%d): %s", desc.DescriptorType(), desc.GetName(), desc.GetID(), test.err) const validateCrossReferencesOnly = catalog.ValidationLevelBackReferences &^ catalog.ValidationLevelSelfOnly results := cb.Validate(ctx, clusterversion.TestingClusterVersion, catalog.NoValidationTelemetry, validateCrossReferencesOnly, desc) diff --git a/pkg/sql/catalog/typedesc/type_desc_test.go b/pkg/sql/catalog/typedesc/type_desc_test.go index c40c3281918e..d7959ae2bdea 100644 --- a/pkg/sql/catalog/typedesc/type_desc_test.go +++ b/pkg/sql/catalog/typedesc/type_desc_test.go @@ -375,20 +375,20 @@ func TestValidateTypeDesc(t *testing.T) { ) var cb nstree.MutableCatalog - cb.UpsertDescriptorEntry(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ + cb.UpsertDescriptor(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ Name: "db", ID: dbID, }).BuildImmutable()) - cb.UpsertDescriptorEntry(schemadesc.NewBuilder(&descpb.SchemaDescriptor{ + cb.UpsertDescriptor(schemadesc.NewBuilder(&descpb.SchemaDescriptor{ ID: schemaID, ParentID: dbID, Name: "schema", }).BuildImmutable()) - cb.UpsertDescriptorEntry(typedesc.NewBuilder(&descpb.TypeDescriptor{ + cb.UpsertDescriptor(typedesc.NewBuilder(&descpb.TypeDescriptor{ ID: typeID, Name: "type", }).BuildImmutable()) - cb.UpsertDescriptorEntry(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ + cb.UpsertDescriptor(dbdesc.NewBuilder(&descpb.DatabaseDescriptor{ Name: "multi-region-db", ID: multiRegionDBID, RegionConfig: &descpb.DatabaseDescriptor_RegionConfig{ diff --git a/pkg/sql/crdb_internal.go b/pkg/sql/crdb_internal.go index 8924b85f7f96..776c3e3b7f80 100644 --- a/pkg/sql/crdb_internal.go +++ b/pkg/sql/crdb_internal.go @@ -597,7 +597,7 @@ func crdbInternalTablesDatabaseLookupFunc( scNames[keys.PublicSchemaID] = catconstants.PublicSchemaName // Record database descriptors for name lookups. dbID := db.GetID() - _ = descs.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = descs.ForEachDescriptor(func(desc catalog.Descriptor) error { if desc.GetParentID() != dbID { return nil } @@ -608,7 +608,7 @@ func crdbInternalTablesDatabaseLookupFunc( }) rf := makeCrdbInternalTablesAddRowFn(p, addRow) var seenAny bool - if err := descs.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + if err := descs.ForEachDescriptor(func(desc catalog.Descriptor) error { if desc.GetParentID() != dbID { return nil } @@ -5176,7 +5176,7 @@ CREATE TABLE crdb_internal.invalid_objects ( { lCtx := newInternalLookupCtx(c.OrderedDescriptors(), dbContext) - if err := c.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + if err := c.ForEachDescriptor(func(desc catalog.Descriptor) error { switch d := desc.(type) { case catalog.DatabaseDescriptor: if dbContext != nil && d.GetID() != dbContext.GetID() { @@ -5486,7 +5486,7 @@ CREATE TABLE crdb_internal.lost_descriptors_with_data ( // shouldCheck returns true iff we expect no data to exist with that // table ID prefix. shouldCheck := func(id descpb.ID) bool { - return minID <= id && id < maxID && c.LookupDescriptorEntry(id) == nil + return minID <= id && id < maxID && c.LookupDescriptor(id) == nil } // hasData returns true iff there exists at least one row with a prefix for // a table ID in [startID, endID[. diff --git a/pkg/sql/doctor/doctor.go b/pkg/sql/doctor/doctor.go index 2fc524a1dc17..0b29c1138c21 100644 --- a/pkg/sql/doctor/doctor.go +++ b/pkg/sql/doctor/doctor.go @@ -184,7 +184,7 @@ func ExamineDescriptors( descReport(stdout, desc, "different id in descriptor table: %d", row.ID) continue } - cb.UpsertDescriptorEntry(desc) + cb.UpsertDescriptor(desc) } for _, row := range descTable { id := descpb.ID(row.ID) diff --git a/pkg/sql/schemachanger/scbackup/job.go b/pkg/sql/schemachanger/scbackup/job.go index 5549ee2762eb..4a908a0fbfe4 100644 --- a/pkg/sql/schemachanger/scbackup/job.go +++ b/pkg/sql/schemachanger/scbackup/job.go @@ -39,7 +39,7 @@ func CreateDeclarativeSchemaChangeJobs( allMut nstree.Catalog, ) error { byJobID := make(map[catpb.JobID][]catalog.MutableDescriptor) - _ = allMut.ForEachDescriptorEntry(func(d catalog.Descriptor) error { + _ = allMut.ForEachDescriptor(func(d catalog.Descriptor) error { if s := d.GetDeclarativeSchemaChangerState(); s != nil { byJobID[s.JobID] = append(byJobID[s.JobID], d.(catalog.MutableDescriptor)) } diff --git a/pkg/sql/schemachanger/scdeps/sctestdeps/config.go b/pkg/sql/schemachanger/scdeps/sctestdeps/config.go index 442cef2cc688..b4be5ba8ad5b 100644 --- a/pkg/sql/schemachanger/scdeps/sctestdeps/config.go +++ b/pkg/sql/schemachanger/scdeps/sctestdeps/config.go @@ -50,7 +50,7 @@ func WithNamespace(c nstree.Catalog) Option { func WithDescriptors(c nstree.Catalog) Option { modifTime := hlc.Timestamp{WallTime: defaultOverriddenCreatedAt.UnixNano()} return optionFunc(func(state *TestState) { - _ = c.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = c.ForEachDescriptor(func(desc catalog.Descriptor) error { mut := desc.NewBuilder().BuildCreatedMutable() switch m := mut.(type) { case *tabledesc.Mutable: @@ -63,8 +63,8 @@ func WithDescriptors(c nstree.Catalog) Option { } mut.ResetModificationTime() desc = mut.ImmutableCopy() - state.committed.UpsertDescriptorEntry(desc) - state.uncommitted.UpsertDescriptorEntry(desc) + state.committed.UpsertDescriptor(desc) + state.uncommitted.UpsertDescriptor(desc) return nil }) }) diff --git a/pkg/sql/schemachanger/scdeps/sctestdeps/database_state.go b/pkg/sql/schemachanger/scdeps/sctestdeps/database_state.go index 3ba11f70b286..75a4374c7143 100644 --- a/pkg/sql/schemachanger/scdeps/sctestdeps/database_state.go +++ b/pkg/sql/schemachanger/scdeps/sctestdeps/database_state.go @@ -97,7 +97,7 @@ ORDER BY id`) t.TypeDescriptor.ModificationTime = hlc.Timestamp{} } - cb.UpsertDescriptorEntry(desc) + cb.UpsertDescriptor(desc) } return cb } @@ -143,7 +143,7 @@ func ReadZoneConfigsFromDB( t *testing.T, tdb *sqlutils.SQLRunner, descCatalog nstree.Catalog, ) map[catid.DescID]catalog.ZoneConfig { zoneCfgMap := make(map[catid.DescID]catalog.ZoneConfig) - require.NoError(t, descCatalog.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + require.NoError(t, descCatalog.ForEachDescriptor(func(desc catalog.Descriptor) error { zoneCfgRow := tdb.Query(t, ` SELECT config FROM system.zones WHERE id=$1 `, diff --git a/pkg/sql/schemachanger/scdeps/sctestdeps/test_deps.go b/pkg/sql/schemachanger/scdeps/sctestdeps/test_deps.go index f56c7481e851..b9a4f958ea06 100644 --- a/pkg/sql/schemachanger/scdeps/sctestdeps/test_deps.go +++ b/pkg/sql/schemachanger/scdeps/sctestdeps/test_deps.go @@ -578,11 +578,11 @@ func (s *TestState) mustReadImmutableDescriptor(id descpb.ID) (catalog.Descripto // mustReadMutableDescriptor looks up a descriptor and returns a mutable // deep copy. func (s *TestState) mustReadMutableDescriptor(id descpb.ID) (catalog.MutableDescriptor, error) { - u := s.uncommitted.LookupDescriptorEntry(id) + u := s.uncommitted.LookupDescriptor(id) if u == nil { return nil, errors.Wrapf(catalog.ErrDescriptorNotFound, "reading mutable descriptor #%d", id) } - c := s.committed.LookupDescriptorEntry(id) + c := s.committed.LookupDescriptor(id) return descbuilder.BuildMutable(c, u.DescriptorProto(), s.mvccTimestamp()) } @@ -773,18 +773,18 @@ func (b *testCatalogChangeBatcher) ValidateAndRun(ctx context.Context) error { } } b.s.LogSideEffectf("delete %s namespace entry %v -> %d", nameType, nameInfo, expectedID) - b.s.uncommitted.DeleteNamespaceEntry(nameInfo) + b.s.uncommitted.DeleteByName(nameInfo) } for _, desc := range b.descs { mut := desc.NewBuilder().BuildCreatedMutable() mut.ResetModificationTime() desc = mut.ImmutableCopy() b.s.LogSideEffectf("upsert descriptor #%d\n%s", desc.GetID(), b.s.descriptorDiff(desc)) - b.s.uncommitted.UpsertDescriptorEntry(desc) + b.s.uncommitted.UpsertDescriptor(desc) } for _, deletedID := range b.descriptorsToDelete.Ordered() { b.s.LogSideEffectf("delete descriptor #%d", deletedID) - b.s.uncommitted.DeleteDescriptorEntry(deletedID) + b.s.uncommitted.DeleteByID(deletedID) } for _, deletedID := range b.zoneConfigsToDelete.Ordered() { b.s.LogSideEffectf("deleting zone config for #%d", deletedID) diff --git a/pkg/sql/schemachanger/scdeps/sctestdeps/test_state.go b/pkg/sql/schemachanger/scdeps/sctestdeps/test_state.go index 3e4f904db716..9927a3651a4a 100644 --- a/pkg/sql/schemachanger/scdeps/sctestdeps/test_state.go +++ b/pkg/sql/schemachanger/scdeps/sctestdeps/test_state.go @@ -119,12 +119,12 @@ func (s *TestState) WithTxn(fn func(s *TestState)) { s.uncommitted.UpsertNamespaceEntry(e, e.GetID(), e.GetMVCCTimestamp()) return nil }) - _ = u.ForEachDescriptorEntry(func(d catalog.Descriptor) error { + _ = u.ForEachDescriptor(func(d catalog.Descriptor) error { mut := d.NewBuilder().BuildCreatedMutable() mut.ResetModificationTime() d = mut.ImmutableCopy() - s.committed.UpsertDescriptorEntry(d) - s.uncommitted.UpsertDescriptorEntry(d) + s.committed.UpsertDescriptor(d) + s.uncommitted.UpsertDescriptor(d) return nil }) s.LogSideEffectf("commit transaction #%d", s.txnCounter) diff --git a/pkg/sql/schemachanger/scexec/exec_backfill_test.go b/pkg/sql/schemachanger/scexec/exec_backfill_test.go index 2929c8af48b4..342d170fc282 100644 --- a/pkg/sql/schemachanger/scexec/exec_backfill_test.go +++ b/pkg/sql/schemachanger/scexec/exec_backfill_test.go @@ -99,7 +99,7 @@ func TestExecBackfiller(t *testing.T) { } findTableWithName := func(c nstree.Catalog, name string) (tab catalog.TableDescriptor) { - _ = c.ForEachDescriptorEntry(func(desc catalog.Descriptor) error { + _ = c.ForEachDescriptor(func(desc catalog.Descriptor) error { var ok bool tab, ok = desc.(catalog.TableDescriptor) if ok && tab.GetName() == name { @@ -132,7 +132,7 @@ func TestExecBackfiller(t *testing.T) { require.NotNil(t, tab) mut := tabledesc.NewBuilder(tab.TableDesc()).BuildExistingMutableTable() addIndexMutation(t, mut, "idx", 2, false /* isTempIndex */, "j") - descs.UpsertDescriptorEntry(mut) + descs.UpsertDescriptor(mut) mc, bt, bf, _, deps := setupTestDeps(t, tdb, descs.Catalog) defer mc.Finish() read, err := deps.Catalog().MustReadImmutableDescriptors(ctx, mut.GetID()) @@ -191,7 +191,7 @@ func TestExecBackfiller(t *testing.T) { mut := tabledesc.NewBuilder(tab.TableDesc()).BuildExistingMutableTable() addIndexMutation(t, mut, "idx", 2, false /* isTempIndex */, "j") addIndexMutation(t, mut, "idx", 3, false /* isTempIndex */, "k", "j") - descs.UpsertDescriptorEntry(mut) + descs.UpsertDescriptor(mut) } var barID descpb.ID { @@ -201,7 +201,7 @@ func TestExecBackfiller(t *testing.T) { mut := tabledesc.NewBuilder(tab.TableDesc()).BuildExistingMutableTable() addIndexMutation(t, mut, "idx", 4, false /* isTempIndex */, "j") addIndexMutation(t, mut, "idx", 5, false /* isTempIndex */, "k", "j") - descs.UpsertDescriptorEntry(mut) + descs.UpsertDescriptor(mut) } mc, bt, bf, _, deps := setupTestDeps(t, tdb, descs.Catalog) @@ -290,7 +290,7 @@ func TestExecBackfiller(t *testing.T) { m.State = descpb.DescriptorMutation_WRITE_ONLY } } - descs.UpsertDescriptorEntry(mut) + descs.UpsertDescriptor(mut) mc, bt, _, m, deps := setupTestDeps(t, tdb, descs.Catalog) defer mc.Finish() read, err := deps.Catalog().MustReadImmutableDescriptors(ctx, mut.GetID()) diff --git a/pkg/sql/schemachanger/sctest/decomp.go b/pkg/sql/schemachanger/sctest/decomp.go index 902d6241dea3..148562a6cdc5 100644 --- a/pkg/sql/schemachanger/sctest/decomp.go +++ b/pkg/sql/schemachanger/sctest/decomp.go @@ -72,7 +72,7 @@ func runDecomposeTest( name := fields[0] var desc catalog.Descriptor allDescs := sctestdeps.ReadDescriptorsFromDB(ctx, t, tdb) - _ = allDescs.ForEachDescriptorEntry(func(d catalog.Descriptor) error { + _ = allDescs.ForEachDescriptor(func(d catalog.Descriptor) error { if d.GetName() == name { desc = d } @@ -86,7 +86,7 @@ func runDecomposeTest( testDeps := sctestdeps.NewTestDependencies( sctestdeps.WithComments(sctestdeps.ReadCommentsFromDB(t, tdb)), sctestdeps.WithZoneConfigs(sctestdeps.ReadZoneConfigsFromDB(t, tdb, allDescs.Catalog))) - backRefs := scdecomp.WalkDescriptor(ctx, desc, allDescs.LookupDescriptorEntry, visitor, testDeps, testDeps) + backRefs := scdecomp.WalkDescriptor(ctx, desc, allDescs.LookupDescriptor, visitor, testDeps, testDeps) return marshalResult(t, m, backRefs) default: