github.com/cockroachdb/cockroach@v20.2.0-alpha.1+incompatible/pkg/sql/opt/norm/limit_funcs.go (about) 1 // Copyright 2020 The Cockroach Authors. 2 // 3 // Use of this software is governed by the Business Source License 4 // included in the file licenses/BSL.txt. 5 // 6 // As of the Change Date specified in that file, in accordance with 7 // the Business Source License, use of this software will be governed 8 // by the Apache License, Version 2.0, included in the file 9 // licenses/APL.txt. 10 11 package norm 12 13 import ( 14 "math" 15 16 "github.com/cockroachdb/cockroach/pkg/sql/opt/memo" 17 "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" 18 ) 19 20 // LimitGeMaxRows returns true if the given constant limit value is greater than 21 // or equal to the max number of rows returned by the input expression. 22 func (c *CustomFuncs) LimitGeMaxRows(limit tree.Datum, input memo.RelExpr) bool { 23 limitVal := int64(*limit.(*tree.DInt)) 24 maxRows := input.Relational().Cardinality.Max 25 return limitVal >= 0 && maxRows < math.MaxUint32 && limitVal >= int64(maxRows) 26 }