Skip to content

Commit

Permalink
sql: fix recording db names with hyphen for idx usage stats
Browse files Browse the repository at this point in the history
Fixes cockroachdb#85577

This commit fixes a bug where the query constructed during
index usage stats recording failed for db names containing
a hyphen. The db name placeholder is now wrapped in double
quotes so the db name can be recognized in the query.

Release justification: bug fix

Release note (bug fix): index usage stats are properly captured
for database names with hyphens
  • Loading branch information
xinhaoz committed Sep 8, 2022
1 parent d33e93f commit 4b5d967
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 8 deletions.
23 changes: 15 additions & 8 deletions pkg/sql/scheduledlogging/captured_index_usage_stats.go
Original file line number Diff line number Diff line change
Expand Up @@ -199,7 +199,14 @@ func captureIndexUsageStats(
JOIN %s.crdb_internal.tables t
ON ti.descriptor_id = t.table_id
ORDER BY total_reads ASC;
`, databaseName, databaseName, databaseName)
FROM %[1]s.crdb_internal.index_usage_statistics AS us
JOIN %[1]s.crdb_internal.table_indexes ti
ON us.index_id = ti.index_id
AND us.table_id = ti.descriptor_id
JOIN %[1]s.crdb_internal.tables t
ON ti.descriptor_id = t.table_id
ORDER BY total_reads ASC; `,
databaseName.String())

it, err := ie.QueryIteratorEx(
ctx,
Expand Down Expand Up @@ -248,7 +255,7 @@ func captureIndexUsageStats(
IndexID: uint32(roachpb.IndexID(indexID)),
TotalReadCount: uint64(totalReads),
LastRead: lastRead.String(),
DatabaseName: databaseName,
DatabaseName: databaseName.String(),
TableName: string(tableName),
IndexName: string(indexName),
IndexType: string(indexType),
Expand Down Expand Up @@ -295,8 +302,8 @@ func logIndexUsageStatsWithDelay(
timer.Stop()
}

func getAllDatabaseNames(ctx context.Context, ie sqlutil.InternalExecutor) ([]string, error) {
var allDatabaseNames []string
func getAllDatabaseNames(ctx context.Context, ie sqlutil.InternalExecutor) (tree.NameList, error) {
var allDatabaseNames tree.NameList
var ok bool
var expectedNumDatums = 1

Expand All @@ -308,7 +315,7 @@ func getAllDatabaseNames(ctx context.Context, ie sqlutil.InternalExecutor) ([]st
`SELECT database_name FROM [SHOW DATABASES]`,
)
if err != nil {
return []string{}, err
return tree.NameList{}, err
}

// We have to make sure to close the iterator since we might return from the
Expand All @@ -317,13 +324,13 @@ func getAllDatabaseNames(ctx context.Context, ie sqlutil.InternalExecutor) ([]st
for ok, err = it.Next(ctx); ok; ok, err = it.Next(ctx) {
var row tree.Datums
if row = it.Cur(); row == nil {
return []string{}, errors.New("unexpected null row while capturing index usage stats")
return tree.NameList{}, errors.New("unexpected null row while capturing index usage stats")
}
if row.Len() != expectedNumDatums {
return []string{}, errors.Newf("expected %d columns, received %d while capturing index usage stats", expectedNumDatums, row.Len())
return tree.NameList{}, errors.Newf("expected %d columns, received %d while capturing index usage stats", expectedNumDatums, row.Len())
}

databaseName := string(tree.MustBeDString(row[0]))
databaseName := tree.Name(tree.MustBeDString(row[0]))
allDatabaseNames = append(allDatabaseNames, databaseName)
}
return allDatabaseNames, nil
Expand Down
3 changes: 3 additions & 0 deletions pkg/sql/scheduledlogging/captured_index_usage_stats_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,9 @@ func TestCaptureIndexUsageStats(t *testing.T) {
db.Exec(t, "CREATE DATABASE test")
db.Exec(t, "CREATE DATABASE test2")

// Test fix for #85577.
db.Exec(t, `CREATE DATABASE "test-hyphen"`)

// Create a table for each database.
db.Exec(t, "CREATE TABLE test.test_table (num INT PRIMARY KEY, letter char)")
db.Exec(t, "CREATE TABLE test2.test2_table (num INT PRIMARY KEY, letter char)")
Expand Down

0 comments on commit 4b5d967

Please sign in to comment.