diff --git a/pkg/ccl/importccl/read_import_mysql.go b/pkg/ccl/importccl/read_import_mysql.go index 62950a297cd4..57216388125f 100644 --- a/pkg/ccl/importccl/read_import_mysql.go +++ b/pkg/ccl/importccl/read_import_mysql.go @@ -264,7 +264,7 @@ func mysqlValueToDatum( return tree.NewDFloat(-*i), nil case *tree.DDecimal: dec := &i.Decimal - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() dd.Decimal.Neg(dec) return dd, nil default: diff --git a/pkg/ccl/importccl/read_import_workload.go b/pkg/ccl/importccl/read_import_workload.go index bb86bd82793e..8107b762b8cc 100644 --- a/pkg/ccl/importccl/read_import_workload.go +++ b/pkg/ccl/importccl/read_import_workload.go @@ -17,7 +17,6 @@ import ( "sync/atomic" "unsafe" - "github.com/cockroachdb/apd/v2" "github.com/cockroachdb/cockroach/pkg/cloud" "github.com/cockroachdb/cockroach/pkg/col/coldata" "github.com/cockroachdb/cockroach/pkg/roachpb" @@ -73,8 +72,9 @@ func makeDatumFromColOffset( case types.IntFamily: return alloc.NewDInt(tree.DInt(col.Int64()[rowIdx])), nil case types.DecimalFamily: - d := *apd.New(col.Int64()[rowIdx], 0) - return alloc.NewDDecimal(tree.DDecimal{Decimal: d}), nil + d := alloc.NewDDecimal(tree.DDecimal{}) + d.SetInt64(col.Int64()[rowIdx]) + return d, nil case types.DateFamily: date, err := pgdate.MakeDateFromUnixEpoch(col.Int64()[rowIdx]) if err != nil { @@ -93,11 +93,11 @@ func makeDatumFromColOffset( case types.FloatFamily: return alloc.NewDFloat(tree.DFloat(col.Float64()[rowIdx])), nil case types.DecimalFamily: - var d apd.Decimal + d := alloc.NewDDecimal(tree.DDecimal{}) if _, err := d.SetFloat64(col.Float64()[rowIdx]); err != nil { return nil, err } - return alloc.NewDDecimal(tree.DDecimal{Decimal: d}), nil + return d, nil } case types.BytesFamily: switch hint.Family() { diff --git a/pkg/col/coldata/vec.go b/pkg/col/coldata/vec.go index 4e468cacb108..fa210bbaff16 100644 --- a/pkg/col/coldata/vec.go +++ b/pkg/col/coldata/vec.go @@ -12,6 +12,8 @@ package coldata import ( "fmt" + "math/big" + "unsafe" "github.com/cockroachdb/cockroach/pkg/col/typeconv" "github.com/cockroachdb/cockroach/pkg/sql/types" @@ -184,7 +186,22 @@ func (cf *defaultColumnFactory) MakeColumn(t *types.T, length int) Column { case types.FloatFamily: return make(Float64s, length) case types.DecimalFamily: - return make(Decimals, length) + d := make(Decimals, length) + // Each Decimal maintains (through an embedded big.Int) an internal + // reference to a variable-length coefficient, which is represented by a + // []big.Word. Pre-allocate a single large []big.Word and distribute chunks + // to each Decimal. big.Int will avoid re-allocating unless it is provided + // with a coefficient that exceeds the initial capacity. We set this + // capacity to accommodate any coefficient that would fit in a 64-bit + // integer (i.e. up to 2^64). + const wordsPer = int(unsafe.Sizeof(uint64(0)) / unsafe.Sizeof(big.Word(0))) + w := make([]big.Word, wordsPer*length) + for i := range d { + low := wordsPer * i + high := wordsPer * (i + 1) + d[i].Coeff.SetBits(w[low:high:high]) + } + return d case types.TimestampTZFamily: return make(Times, length) case types.IntervalFamily: diff --git a/pkg/sql/colexec/colexectestutils/utils.go b/pkg/sql/colexec/colexectestutils/utils.go index 665bf2e29e9b..8271db428904 100644 --- a/pkg/sql/colexec/colexectestutils/utils.go +++ b/pkg/sql/colexec/colexectestutils/utils.go @@ -1401,8 +1401,15 @@ func tupleEquals(expected Tuple, actual Tuple, evalCtx *tree.EvalContext) bool { } // Special case for decimals. if d1, ok := actual[i].(apd.Decimal); ok { - if f2, ok := expected[i].(float64); ok { - d2, _, err := apd.NewFromString(fmt.Sprintf("%f", f2)) + switch t := expected[i].(type) { + case apd.Decimal: + if d1.Cmp(&t) == 0 { + continue + } else { + return false + } + case float64: + d2, _, err := apd.NewFromString(fmt.Sprintf("%f", t)) if err == nil && d1.Cmp(d2) == 0 { continue } else { diff --git a/pkg/sql/colexec/execgen/cmd/execgen/vec_to_datum_gen.go b/pkg/sql/colexec/execgen/cmd/execgen/vec_to_datum_gen.go index cf23257023de..5ccc0aed374d 100644 --- a/pkg/sql/colexec/execgen/cmd/execgen/vec_to_datum_gen.go +++ b/pkg/sql/colexec/execgen/cmd/execgen/vec_to_datum_gen.go @@ -67,14 +67,10 @@ var vecToDatumConversionTmpls = map[types.Family]string{ types.BoolFamily: `%[1]s := tree.MakeDBool(tree.DBool(%[2]s))`, // Note that currently, regardless of the integer's width, we always return // INT8, so there is a single conversion template for IntFamily. - types.IntFamily: `%[1]s := %[3]s.NewDInt(tree.DInt(%[2]s))`, - types.FloatFamily: `%[1]s := %[3]s.NewDFloat(tree.DFloat(%[2]s))`, - types.DecimalFamily: ` %[1]s := %[3]s.NewDDecimal(tree.DDecimal{Decimal: %[2]s}) - // Clear the Coeff so that the Set below allocates a new slice for the - // Coeff.abs field. - %[1]s.Coeff = big.Int{} - %[1]s.Coeff.Set(&%[2]s.Coeff)`, - types.DateFamily: `%[1]s := %[3]s.NewDDate(tree.DDate{Date: pgdate.MakeCompatibleDateFromDisk(%[2]s)})`, + types.IntFamily: `%[1]s := %[3]s.NewDInt(tree.DInt(%[2]s))`, + types.FloatFamily: `%[1]s := %[3]s.NewDFloat(tree.DFloat(%[2]s))`, + types.DecimalFamily: `%[1]s := %[3]s.NewDDecimal(tree.DDecimal{Decimal: %[2]s})`, + types.DateFamily: `%[1]s := %[3]s.NewDDate(tree.DDate{Date: pgdate.MakeCompatibleDateFromDisk(%[2]s)})`, types.BytesFamily: `// Note that there is no need for a copy since DBytes uses a string // as underlying storage, which will perform the copy for us. %[1]s := %[3]s.NewDBytes(tree.DBytes(%[2]s))`, diff --git a/pkg/sql/exec_util.go b/pkg/sql/exec_util.go index 7cb3ee28fa53..67e9b69d43fc 100644 --- a/pkg/sql/exec_util.go +++ b/pkg/sql/exec_util.go @@ -1554,7 +1554,7 @@ func golangFillQueryArguments(args ...interface{}) (tree.Datums, error) { case bitarray.BitArray: d = &tree.DBitArray{BitArray: t} case *apd.Decimal: - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() dd.Set(t) d = dd case security.SQLUsername: diff --git a/pkg/sql/randgen/datum.go b/pkg/sql/randgen/datum.go index ef5cbf26884c..0c88b5bdc1f3 100644 --- a/pkg/sql/randgen/datum.go +++ b/pkg/sql/randgen/datum.go @@ -116,7 +116,7 @@ func RandDatumWithNullChance(rng *rand.Rand, typ *types.T, nullChance int) tree. } return tree.NewDGeometry(geogen.RandomGeometry(rng, gm.SRID)) case types.DecimalFamily: - d := &tree.DDecimal{} + d := tree.NewDDecimal() // int64(rng.Uint64()) to get negative numbers, too d.Decimal.SetFinite(int64(rng.Uint64()), int32(rng.Intn(40)-20)) return d diff --git a/pkg/sql/rowenc/datum_alloc.go b/pkg/sql/rowenc/datum_alloc.go index be271d1b61a4..8f3c129d28d0 100644 --- a/pkg/sql/rowenc/datum_alloc.go +++ b/pkg/sql/rowenc/datum_alloc.go @@ -34,7 +34,7 @@ type DatumAlloc struct { dstringAlloc []tree.DString dbytesAlloc []tree.DBytes dbitArrayAlloc []tree.DBitArray - ddecimalAlloc []tree.DDecimal + ddecimalAlloc []tree.DDecimalAlloc ddateAlloc []tree.DDate denumAlloc []tree.DEnum dbox2dAlloc []tree.DBox2D @@ -170,10 +170,10 @@ func (a *DatumAlloc) NewDDecimal(v tree.DDecimal) *tree.DDecimal { } buf := &a.ddecimalAlloc if len(*buf) == 0 { - *buf = make([]tree.DDecimal, a.AllocSize) + *buf = make([]tree.DDecimalAlloc, a.AllocSize) } - r := &(*buf)[0] - *r = v + r := (*buf)[0].Get() + r.Set(&v.Decimal) *buf = (*buf)[1:] return r } diff --git a/pkg/sql/rowexec/processor_utils_test.go b/pkg/sql/rowexec/processor_utils_test.go index 836ba394a37d..936a5d5d2212 100644 --- a/pkg/sql/rowexec/processor_utils_test.go +++ b/pkg/sql/rowexec/processor_utils_test.go @@ -60,7 +60,7 @@ func toEncDatum(datumType *types.T, v interface{}) rowenc.EncDatum { switch concreteType := v.(type) { case int: if datumType.Family() == types.DecimalFamily { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() dd.SetInt64(int64(v.(int))) return dd } diff --git a/pkg/sql/sem/builtins/aggregate_builtins.go b/pkg/sql/sem/builtins/aggregate_builtins.go index 4a4892eb26ec..67243b2370da 100644 --- a/pkg/sql/sem/builtins/aggregate_builtins.go +++ b/pkg/sql/sem/builtins/aggregate_builtins.go @@ -2577,7 +2577,7 @@ func (a *intSumAggregate) Result() (tree.Datum, error) { if !a.seenNonNull { return tree.DNull, nil } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() if a.large { dd.Set(&a.decSum) } else { @@ -2644,7 +2644,7 @@ func (a *decimalSumAggregate) Result() (tree.Datum, error) { if !a.sawNonNull { return tree.DNull, nil } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() dd.Set(&a.sum) return dd, nil } @@ -2947,7 +2947,7 @@ func (a *decimalSqrDiffAggregate) Result() (tree.Datum, error) { if a.count.Cmp(decimalOne) < 0 { return tree.DNull, nil } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() dd.Set(&a.sqrDiff) // Remove trailing zeros. Depending on the order in which the input // is processed, some number of trailing zeros could be added to the @@ -3267,7 +3267,7 @@ func (a *decimalVarianceAggregate) Result() (tree.Datum, error) { if _, err = tree.IntermediateCtx.Sub(a.agg.Tmp(), a.agg.Count(), decimalOne); err != nil { return nil, err } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() if _, err = tree.DecimalCtx.Quo(&dd.Decimal, &sqrDiff.(*tree.DDecimal).Decimal, a.agg.Tmp()); err != nil { return nil, err } @@ -3382,7 +3382,7 @@ func (a *decimalVarPopAggregate) Result() (tree.Datum, error) { if err != nil { return nil, err } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() if _, err = tree.DecimalCtx.Quo(&dd.Decimal, &sqrDiff.(*tree.DDecimal).Decimal, a.agg.Count()); err != nil { return nil, err } diff --git a/pkg/sql/sem/builtins/aggregate_builtins_test.go b/pkg/sql/sem/builtins/aggregate_builtins_test.go index 2a6248eba049..b33e03223c2f 100644 --- a/pkg/sql/sem/builtins/aggregate_builtins_test.go +++ b/pkg/sql/sem/builtins/aggregate_builtins_test.go @@ -499,7 +499,7 @@ func makeDecimalTestDatum(count int) []tree.Datum { vals := make([]tree.Datum, count) for i := range vals { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() if _, err := dd.SetFloat64(rng.Float64()); err != nil { panic(err) } diff --git a/pkg/sql/sem/builtins/math_builtins.go b/pkg/sql/sem/builtins/math_builtins.go index b439a469e953..fc974307b410 100644 --- a/pkg/sql/sem/builtins/math_builtins.go +++ b/pkg/sql/sem/builtins/math_builtins.go @@ -53,7 +53,7 @@ var mathBuiltins = map[string]builtinDefinition{ return tree.NewDFloat(tree.DFloat(math.Abs(x))), nil }, "Calculates the absolute value of `val`.", tree.VolatilityImmutable), decimalOverload1(func(x *apd.Decimal) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() dd.Abs(x) return dd, nil }, "Calculates the absolute value of `val`.", tree.VolatilityImmutable), @@ -197,7 +197,7 @@ var mathBuiltins = map[string]builtinDefinition{ if y.Sign() == 0 { return nil, tree.ErrDivByZero } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.HighPrecisionCtx.QuoInteger(&dd.Decimal, x, y) return dd, err }, "Calculates the integer quotient of `x`/`y`.", tree.VolatilityImmutable), @@ -222,7 +222,7 @@ var mathBuiltins = map[string]builtinDefinition{ return tree.NewDFloat(tree.DFloat(math.Exp(x))), nil }, "Calculates *e* ^ `val`.", tree.VolatilityImmutable), decimalOverload1(func(x *apd.Decimal) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.DecimalCtx.Exp(&dd.Decimal, x) return dd, err }, "Calculates *e* ^ `val`.", tree.VolatilityImmutable), @@ -233,7 +233,7 @@ var mathBuiltins = map[string]builtinDefinition{ return tree.NewDFloat(tree.DFloat(math.Floor(x))), nil }, "Calculates the largest integer not greater than `val`.", tree.VolatilityImmutable), decimalOverload1(func(x *apd.Decimal) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.ExactCtx.Floor(&dd.Decimal, x) return dd, err }, "Calculates the largest integer not greater than `val`.", tree.VolatilityImmutable), @@ -322,7 +322,7 @@ var mathBuiltins = map[string]builtinDefinition{ return nil, err } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.DecimalCtx.Quo(&dd.Decimal, top, bot) return dd, err }, "Calculates the base `b` log of `val`.", tree.VolatilityImmutable), @@ -336,7 +336,7 @@ var mathBuiltins = map[string]builtinDefinition{ if y.Sign() == 0 { return nil, tree.ErrDivByZero } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.HighPrecisionCtx.Rem(&dd.Decimal, x, y) return dd, err }, "Calculates `x`%`y`.", tree.VolatilityImmutable), @@ -462,7 +462,7 @@ var mathBuiltins = map[string]builtinDefinition{ }, "Determines the sign of `val`: **1** for positive; **0** for 0 values; **-1** for "+ "negative.", tree.VolatilityImmutable), decimalOverload1(func(x *apd.Decimal) (tree.Datum, error) { - d := &tree.DDecimal{} + d := tree.NewDDecimal() d.Decimal.SetInt64(int64(x.Sign())) return d, nil }, "Determines the sign of `val`: **1** for positive; **0** for 0 values; **-1** for "+ @@ -518,7 +518,7 @@ var mathBuiltins = map[string]builtinDefinition{ return tree.NewDFloat(tree.DFloat(math.Trunc(x))), nil }, "Truncates the decimal values of `val`.", tree.VolatilityImmutable), decimalOverload1(func(x *apd.Decimal) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() x.Modf(&dd.Decimal, nil) return dd, nil }, "Truncates the decimal values of `val`.", tree.VolatilityImmutable), @@ -593,7 +593,7 @@ var ceilImpl = makeBuiltin(defProps(), return tree.NewDFloat(tree.DFloat(math.Ceil(x))), nil }, "Calculates the smallest integer not smaller than `val`.", tree.VolatilityImmutable), decimalOverload1(func(x *apd.Decimal) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.ExactCtx.Ceil(&dd.Decimal, x) if dd.IsZero() { dd.Negative = false @@ -616,7 +616,7 @@ var powImpls = makeBuiltin(defProps(), return tree.NewDFloat(tree.DFloat(math.Pow(x, y))), nil }, "Calculates `x`^`y`.", tree.VolatilityImmutable), decimalOverload2("x", "y", func(x, y *apd.Decimal) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.DecimalCtx.Pow(&dd.Decimal, x, y) return dd, err }, "Calculates `x`^`y`.", tree.VolatilityImmutable), @@ -646,7 +646,7 @@ func decimalLogFn( case 0: return nil, errLogOfZero } - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := logFn(&dd.Decimal, x) return dd, err }, info, tree.VolatilityImmutable) @@ -730,7 +730,7 @@ func roundDDecimal(d *tree.DDecimal, scale int32) (tree.Datum, error) { } func roundDecimal(x *apd.Decimal, scale int32) (tree.Datum, error) { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() _, err := tree.HighPrecisionCtx.Quantize(&dd.Decimal, x, -scale) return dd, err } diff --git a/pkg/sql/sem/builtins/window_frame_builtins.go b/pkg/sql/sem/builtins/window_frame_builtins.go index f54138605d8c..99892eb8f3d2 100644 --- a/pkg/sql/sem/builtins/window_frame_builtins.go +++ b/pkg/sql/sem/builtins/window_frame_builtins.go @@ -246,9 +246,9 @@ func (w *slidingWindowSumFunc) removeAllBefore( case *tree.DInt: err = w.agg.Add(ctx, tree.NewDInt(-*v)) case *tree.DDecimal: - d := tree.DDecimal{} + d := tree.NewDDecimal() d.Neg(&v.Decimal) - err = w.agg.Add(ctx, &d) + err = w.agg.Add(ctx, d) case *tree.DFloat: err = w.agg.Add(ctx, tree.NewDFloat(-*v)) case *tree.DInterval: @@ -405,7 +405,7 @@ func (w *avgWindowFunc) Compute( _, err := tree.DecimalCtx.Quo(&avg.Decimal, &t.Decimal, count) return &avg, err case *tree.DInt: - dd := tree.DDecimal{} + dd := tree.NewDDecimal() dd.SetInt64(int64(*t)) var avg tree.DDecimal count := apd.New(int64(frameSize), 0) diff --git a/pkg/sql/sem/tree/datum.go b/pkg/sql/sem/tree/datum.go index 123d8c6840ae..860a4f809be7 100644 --- a/pkg/sql/sem/tree/datum.go +++ b/pkg/sql/sem/tree/datum.go @@ -996,6 +996,35 @@ type DDecimal struct { apd.Decimal } +// DDecimalAlloc attempts to minimize heap allocations when using a DDecimal. +// Each Decimal maintains (through an embedded big.Int) an internal reference +// to a variable-length coefficient, which is represented by a []big.Word. To +// minimize the number of individual heap allocations, we allocate a small +// []big.Word alongside the DDecimal and wire the two up. big.Int will avoid +// re-allocating unless its coefficient exceeds the initial capacity. We set +// this capacity to accommodate any coefficient that would fit in a 64-bit +// integer. +type DDecimalAlloc struct { + d DDecimal + w [unsafe.Sizeof(uint64(0)) / unsafe.Sizeof(big.Word(0))]big.Word +} + +// Get returns the allocated DDecimal. +func (d *DDecimalAlloc) Get() *DDecimal { + if d.d.Coeff.Bits() == nil { + d.d.Coeff.SetBits(d.w[:]) + } + return &d.d +} + +// NewDDecimal is a helper routine to create a *DDecimal. The function attempts +// to allocate the Decimal and its internal, variable-length references in a +// single heap allocation. +func NewDDecimal() *DDecimal { + a := new(DDecimalAlloc) + return a.Get() +} + // MustBeDDecimal attempts to retrieve a DDecimal from an Expr, panicking if the // assertion fails. func MustBeDDecimal(e Expr) DDecimal { @@ -1009,7 +1038,7 @@ func MustBeDDecimal(e Expr) DDecimal { // ParseDDecimal parses and returns the *DDecimal Datum value represented by the // provided string, or an error if parsing is unsuccessful. func ParseDDecimal(s string) (*DDecimal, error) { - dd := &DDecimal{} + dd := NewDDecimal() err := dd.SetString(s) return dd, err } diff --git a/pkg/sql/sem/tree/eval.go b/pkg/sql/sem/tree/eval.go index a1a9b88f8a06..8933195bda43 100644 --- a/pkg/sql/sem/tree/eval.go +++ b/pkg/sql/sem/tree/eval.go @@ -192,7 +192,7 @@ var UnaryOps = unaryOpFixups(map[UnaryOperatorSymbol]unaryOpOverload{ ReturnType: types.Decimal, Fn: func(_ *EvalContext, d Datum) (Datum, error) { dec := &d.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() dd.Decimal.Neg(dec) return dd, nil }, @@ -696,7 +696,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() _, err := ExactCtx.Add(&dd.Decimal, l, r) return dd, err }, @@ -709,7 +709,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := MustBeDInt(right) - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := ExactCtx.Add(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -723,7 +723,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := MustBeDInt(left) r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := ExactCtx.Add(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -991,7 +991,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() _, err := ExactCtx.Sub(&dd.Decimal, l, r) return dd, err }, @@ -1004,7 +1004,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := MustBeDInt(right) - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := ExactCtx.Sub(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -1018,7 +1018,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := MustBeDInt(left) r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := ExactCtx.Sub(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -1313,7 +1313,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() _, err := ExactCtx.Mul(&dd.Decimal, l, r) return dd, err }, @@ -1329,7 +1329,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := MustBeDInt(right) - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := ExactCtx.Mul(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -1343,7 +1343,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := MustBeDInt(left) r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := ExactCtx.Mul(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -1429,7 +1429,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ return nil, ErrDivByZero } div := ctx.getTmpDec().SetInt64(int64(rInt)) - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(MustBeDInt(left))) _, err := DecimalCtx.Quo(&dd.Decimal, &dd.Decimal, div) return dd, err @@ -1459,7 +1459,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r.IsZero() { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() _, err := DecimalCtx.Quo(&dd.Decimal, l, r) return dd, err }, @@ -1475,7 +1475,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r == 0 { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := DecimalCtx.Quo(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -1492,7 +1492,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r.IsZero() { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := DecimalCtx.Quo(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -1565,7 +1565,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r.IsZero() { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() _, err := HighPrecisionCtx.QuoInteger(&dd.Decimal, l, r) return dd, err }, @@ -1581,7 +1581,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r == 0 { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := HighPrecisionCtx.QuoInteger(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -1598,7 +1598,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r.IsZero() { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := HighPrecisionCtx.QuoInteger(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -1645,7 +1645,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r.IsZero() { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() _, err := HighPrecisionCtx.Rem(&dd.Decimal, l, r) return dd, err }, @@ -1661,7 +1661,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r == 0 { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := HighPrecisionCtx.Rem(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -1678,7 +1678,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ if r.IsZero() { return nil, ErrDivByZero } - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := HighPrecisionCtx.Rem(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -1844,7 +1844,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() _, err := DecimalCtx.Pow(&dd.Decimal, l, r) return dd, err }, @@ -1857,7 +1857,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := &left.(*DDecimal).Decimal r := MustBeDInt(right) - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(r)) _, err := DecimalCtx.Pow(&dd.Decimal, l, &dd.Decimal) return dd, err @@ -1871,7 +1871,7 @@ var BinOps = map[BinaryOperatorSymbol]binOpOverload{ Fn: func(_ *EvalContext, left Datum, right Datum) (Datum, error) { l := MustBeDInt(left) r := &right.(*DDecimal).Decimal - dd := &DDecimal{} + dd := NewDDecimal() dd.SetInt64(int64(l)) _, err := DecimalCtx.Pow(&dd.Decimal, &dd.Decimal, r) return dd, err @@ -5713,7 +5713,7 @@ func DecimalSqrt(x *apd.Decimal) (*DDecimal, error) { if x.Sign() < 0 { return nil, errSqrtOfNegNumber } - dd := &DDecimal{} + dd := NewDDecimal() _, err := DecimalCtx.Sqrt(&dd.Decimal, x) return dd, err } @@ -5725,7 +5725,7 @@ func Cbrt(x float64) (*DFloat, error) { // DecimalCbrt returns the cube root of x. func DecimalCbrt(x *apd.Decimal) (*DDecimal, error) { - dd := &DDecimal{} + dd := NewDDecimal() _, err := DecimalCtx.Cbrt(&dd.Decimal, x) return dd, err } diff --git a/pkg/sql/sem/tree/testutils.go b/pkg/sql/sem/tree/testutils.go index ba65bfd458b5..2fecd6435737 100644 --- a/pkg/sql/sem/tree/testutils.go +++ b/pkg/sql/sem/tree/testutils.go @@ -49,7 +49,7 @@ func SampleDatum(t *types.T) Datum { f := DFloat(123.456) return &f case types.DecimalFamily: - d := &DDecimal{} + d := NewDDecimal() // int64(rng.Uint64()) to get negative numbers, too d.Decimal.SetFinite(3, 6) return d diff --git a/pkg/sql/sem/tree/type_check_internal_test.go b/pkg/sql/sem/tree/type_check_internal_test.go index 4776378a9f75..c67a1c0f59fa 100644 --- a/pkg/sql/sem/tree/type_check_internal_test.go +++ b/pkg/sql/sem/tree/type_check_internal_test.go @@ -127,7 +127,7 @@ func dint(i tree.DInt) copyableExpr { } func ddecimal(f float64) copyableExpr { return func() tree.Expr { - dd := &tree.DDecimal{} + dd := tree.NewDDecimal() if _, err := dd.SetFloat64(f); err != nil { panic(err) } diff --git a/pkg/sql/sem/tree/window_funcs_test.go b/pkg/sql/sem/tree/window_funcs_test.go index 3b488d7eb0b1..26a57ea6988b 100644 --- a/pkg/sql/sem/tree/window_funcs_test.go +++ b/pkg/sql/sem/tree/window_funcs_test.go @@ -73,9 +73,9 @@ func testStartPreceding( case types.FloatFamily: typedOffset = NewDFloat(DFloat(offset)) case types.DecimalFamily: - decimal := apd.Decimal{} + decimal := NewDDecimal() decimal.SetInt64(int64(offset)) - typedOffset = &DDecimal{Decimal: decimal} + typedOffset = decimal default: t.Fatal("unsupported offset type") } @@ -123,9 +123,9 @@ func testStartFollowing( case types.FloatFamily: typedOffset = NewDFloat(DFloat(offset)) case types.DecimalFamily: - decimal := apd.Decimal{} + decimal := NewDDecimal() decimal.SetInt64(int64(offset)) - typedOffset = &DDecimal{Decimal: decimal} + typedOffset = decimal default: t.Fatal("unsupported offset type") } @@ -182,9 +182,9 @@ func testEndPreceding( case types.FloatFamily: typedOffset = NewDFloat(DFloat(offset)) case types.DecimalFamily: - decimal := apd.Decimal{} + decimal := NewDDecimal() decimal.SetInt64(int64(offset)) - typedOffset = &DDecimal{Decimal: decimal} + typedOffset = decimal default: t.Fatal("unsupported offset type") } @@ -232,9 +232,9 @@ func testEndFollowing( case types.FloatFamily: typedOffset = NewDFloat(DFloat(offset)) case types.DecimalFamily: - decimal := apd.Decimal{} + decimal := NewDDecimal() decimal.SetInt64(int64(offset)) - typedOffset = &DDecimal{Decimal: decimal} + typedOffset = decimal default: t.Fatal("unsupported offset type") } @@ -296,7 +296,7 @@ func makeFloatSortedPartition(count int) indexedRows { func makeDecimalSortedPartition(t *testing.T, count int) indexedRows { partition := indexedRows{rows: make([]indexedRow, count)} r := rand.New(rand.NewSource(timeutil.Now().UnixNano())) - number := &DDecimal{} + number := NewDDecimal() for idx := 0; idx < count; idx++ { tmp := apd.Decimal{} if r.Float64() < probabilityOfNewNumber { @@ -309,7 +309,7 @@ func makeDecimalSortedPartition(t *testing.T, count int) indexedRows { t.Fatalf("unexpected error: %v", err) } } - value := &DDecimal{} + value := NewDDecimal() _, err := tmp.SetFloat64(0) if err != nil { t.Fatalf("unexpected error: %v", err)