Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix SchemaStats to return empty stats #1359

Merged
merged 31 commits into from
Nov 9, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
4b29a73
WIP
Oct 12, 2022
92e821f
WIP
Oct 12, 2022
83a68fe
Merge branch 'main' of https://github.com/w84thesun/FerretDB
Oct 18, 2022
9b1e885
merge conflicts
Oct 20, 2022
ce440cb
Merge branch 'main' of https://github.com/FerretDB/FerretDB
Oct 21, 2022
31ecf5c
Merge branch 'main' of https://github.com/FerretDB/FerretDB
Oct 24, 2022
5b29d95
Merge branch 'main' of https://github.com/FerretDB/FerretDB
Oct 25, 2022
7c9d053
Merge branch 'main' of https://github.com/FerretDB/FerretDB
Oct 27, 2022
2e8d978
Merge remote-tracking branch 'upstream/main'
Oct 28, 2022
fc972ac
Merge branch 'main' of https://github.com/FerretDB/FerretDB
Oct 31, 2022
ad2dddf
Merge branch 'main' of https://github.com/FerretDB/FerretDB
Nov 2, 2022
93425cb
WIP
Nov 2, 2022
1b998b6
Merge branch 'main' into issue-1317-fix-schema-stats
Nov 3, 2022
3ede7d8
WIP
Nov 4, 2022
d36af6e
Merge remote-tracking branch 'origin/issue-1317-fix-schema-stats' int…
Nov 4, 2022
d51d29d
Merge branch 'main' into issue-1317-fix-schema-stats
Nov 4, 2022
2fbea99
WIP
Nov 4, 2022
6c39c3e
Merge remote-tracking branch 'origin/issue-1317-fix-schema-stats' int…
Nov 4, 2022
06123e3
Merge branch 'main' into issue-1317-fix-schema-stats
Nov 4, 2022
61cab15
Merge branch 'main' into issue-1317-fix-schema-stats
Nov 4, 2022
1ed16b0
WIP
Nov 4, 2022
8c9895e
wip
rumyantseva Nov 8, 2022
888c3c5
no docusaurus
rumyantseva Nov 8, 2022
7c98377
revert the change that wasn't needed
rumyantseva Nov 8, 2022
138fddb
cover both cases
rumyantseva Nov 8, 2022
f5ac179
wip
rumyantseva Nov 8, 2022
f7bdbd0
Merge branch 'main' into issue-1317-fix-schema-stats
Nov 8, 2022
17b6e7a
fix gomod
rumyantseva Nov 8, 2022
b117bd4
Merge branch 'main' into issue-1317-fix-schema-stats
mergify[bot] Nov 8, 2022
fca25fe
godoc
rumyantseva Nov 9, 2022
7366726
Merge branch 'main' into issue-1317-fix-schema-stats
mergify[bot] Nov 9, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
WIP
  • Loading branch information
w84thesun committed Nov 4, 2022
commit 3ede7d83c029a04a7a85f05ac9f178a2b52e04e8
4 changes: 2 additions & 2 deletions internal/handlers/pg/msg_serverstatus.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,13 @@ func (h *Handler) MsgServerStatus(ctx context.Context, msg *wire.OpMsg) (*wire.O
return nil, lazyerrors.Error(err)
}

stats, err := h.PgPool.SchemaStats(ctx, "", "")
_, err = h.PgPool.SchemaStats(ctx, "", "")
if err != nil {
return nil, lazyerrors.Error(err)
}

res.Set("catalogStats", must.NotFail(types.NewDocument(
"collections", stats.CountTables,
"collections", int32(0),
"capped", int32(0),
"timeseries", int32(0),
"views", int32(0),
Expand Down
39 changes: 1 addition & 38 deletions internal/handlers/pg/pgdb/pool.go
Original file line number Diff line number Diff line change
Expand Up @@ -180,44 +180,7 @@ func (pgPool *Pool) checkConnection(ctx context.Context) error {
// If schema is empty, it calculates statistics across the whole PostgreSQL database.
// If collection is empty it calculates statistics across the whole PostgreSQL schema.
func (pgPool *Pool) SchemaStats(ctx context.Context, schema, collection string) (*DBStats, error) {
var res DBStats

sql := `
SELECT COUNT(distinct t.table_name) AS CountTables,
COALESCE(SUM(s.n_live_tup), 0) AS CountRows,
COALESCE(SUM(pg_total_relation_size('"'||t.table_schema||'"."'||t.table_name||'"')), 0) AS SizeTotal,
COALESCE(SUM(pg_indexes_size('"'||t.table_schema||'"."'||t.table_name||'"')), 0) AS SizeIndexes,
COALESCE(SUM(pg_relation_size('"'||t.table_schema||'"."'||t.table_name||'"')), 0) AS SizeRelation,
COUNT(distinct i.indexname) AS CountIndexes
FROM information_schema.tables AS t
LEFT OUTER
JOIN pg_stat_user_tables AS s ON s.schemaname = t.table_schema
AND s.relname = t.table_name
LEFT OUTER
JOIN pg_indexes AS i ON i.schemaname = t.table_schema
AND i.tablename = t.table_name`

// TODO Exclude service schemas from the query above https://github.com/FerretDB/FerretDB/issues/1068

args := []any{}

if schema != "" {
sql += " WHERE t.table_schema = $1"
args = append(args, schema)

if collection != "" {
sql += " AND t.table_name = $2"
args = append(args, collection)
}
}

res.Name = schema
err := pgPool.QueryRow(ctx, sql, args...).
Scan(&res.CountTables, &res.CountRows, &res.SizeTotal, &res.SizeIndexes, &res.SizeRelation, &res.CountIndexes)
if err != nil {
return nil, lazyerrors.Error(err)
}
return &res, nil
return nil, nil
}

// InTransaction wraps the given function f in a transaction.
Expand Down