Support estimated count with multiple schemas (#22276)
The `EstimateCount` could be incorrect when the table lives in multiple schemas. Related to #19775.
This commit is contained in:
parent
cf07f247b7
commit
e5deeda0aa
1 changed files with 4 additions and 1 deletions
|
@ -188,7 +188,10 @@ func EstimateCount(ctx context.Context, bean interface{}) (int64, error) {
|
||||||
case schemas.MYSQL:
|
case schemas.MYSQL:
|
||||||
_, err = e.Context(ctx).SQL("SELECT table_rows FROM information_schema.tables WHERE tables.table_name = ? AND tables.table_schema = ?;", tablename, x.Dialect().URI().DBName).Get(&rows)
|
_, err = e.Context(ctx).SQL("SELECT table_rows FROM information_schema.tables WHERE tables.table_name = ? AND tables.table_schema = ?;", tablename, x.Dialect().URI().DBName).Get(&rows)
|
||||||
case schemas.POSTGRES:
|
case schemas.POSTGRES:
|
||||||
_, err = e.Context(ctx).SQL("SELECT reltuples AS estimate FROM pg_class WHERE relname = ?;", tablename).Get(&rows)
|
// the table can live in multiple schemas of a postgres database
|
||||||
|
// See https://wiki.postgresql.org/wiki/Count_estimate
|
||||||
|
tablename = x.TableName(bean, true)
|
||||||
|
_, err = e.Context(ctx).SQL("SELECT reltuples::bigint AS estimate FROM pg_class WHERE oid = ?::regclass;", tablename).Get(&rows)
|
||||||
case schemas.MSSQL:
|
case schemas.MSSQL:
|
||||||
_, err = e.Context(ctx).SQL("sp_spaceused ?;", tablename).Get(&rows)
|
_, err = e.Context(ctx).SQL("sp_spaceused ?;", tablename).Get(&rows)
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in a new issue