Skip to content

Commit

Permalink
opt: remove TODOs related to UDFs named "count"
Browse files Browse the repository at this point in the history
Related to #89543

Release note: None
  • Loading branch information
mgartner committed Oct 6, 2022
1 parent 06d3121 commit 2bf8569
Showing 1 changed file with 3 additions and 6 deletions.
9 changes: 3 additions & 6 deletions pkg/sql/opt/optbuilder/scope.go
Original file line number Diff line number Diff line change
Expand Up @@ -1534,6 +1534,9 @@ func (s *scope) replaceCount(
}
f.Exprs[0] = vn

// It is ok to use string equality here, even if there is a UDF named
// "count" because UDFs cannot be aggregate functions. This code path is
// only executed for aggregate functions.
if strings.EqualFold(def.Name, "count") && f.Type == 0 {
if _, ok := vn.(tree.UnqualifiedStar); ok {
if f.Filter != nil {
Expand All @@ -1548,9 +1551,6 @@ func (s *scope) replaceCount(
e := &cpy
e.Exprs = tree.Exprs{tree.DBoolTrue}

// TODO(mgartner): What happens if a user defines a UDF named
// "count"? We might need to resolve the function first, not
// just rely on string equality to "count" above.
newDef, err := e.Func.Resolve(s.builder.ctx, s.builder.semaCtx.SearchPath, nil /* resolver */)
if err != nil {
panic(err)
Expand All @@ -1577,9 +1577,6 @@ func (s *scope) replaceCount(
if _, err := e.TypeCheck(s.builder.ctx, &semaCtx, types.Any); err != nil {
panic(err)
}
// TODO(mgartner): What happens if a user defines a UDF named
// "count"? We might need to resolve the function first, not just
// rely on string equality to "count" above.
newDef, err := e.Func.Resolve(s.builder.ctx, s.builder.semaCtx.SearchPath, nil /* resolver */)
if err != nil {
panic(err)
Expand Down

0 comments on commit 2bf8569

Please sign in to comment.