aboutsummaryrefslogtreecommitdiff
path: root/src/backend/utils/adt/numeric.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2007-07-09 16:13:57 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2007-07-09 16:13:57 +0000
commit6244c2dfff6fa1b98fc8f13e59f656a20fad3564 (patch)
tree33fa2e1c2ad186d9c7e17dc64d6be9e1e4cb0e3c /src/backend/utils/adt/numeric.c
parent9e09e3b15eb2673c96a2a3f92133311bba0e949c (diff)
downloadpostgresql-6244c2dfff6fa1b98fc8f13e59f656a20fad3564.tar.gz
postgresql-6244c2dfff6fa1b98fc8f13e59f656a20fad3564.zip
Fix stddev_pop(numeric) and var_pop(numeric), which were incorrectly producing
the same outputs as stddev_samp() and var_samp() respectively.
Diffstat (limited to 'src/backend/utils/adt/numeric.c')
-rw-r--r--src/backend/utils/adt/numeric.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/backend/utils/adt/numeric.c b/src/backend/utils/adt/numeric.c
index 02523b8a5fc..e40e0470fb7 100644
--- a/src/backend/utils/adt/numeric.c
+++ b/src/backend/utils/adt/numeric.c
@@ -14,7 +14,7 @@
* Copyright (c) 1998-2007, PostgreSQL Global Development Group
*
* IDENTIFICATION
- * $PostgreSQL: pgsql/src/backend/utils/adt/numeric.c,v 1.105 2007/06/15 20:56:50 tgl Exp $
+ * $PostgreSQL: pgsql/src/backend/utils/adt/numeric.c,v 1.106 2007/07/09 16:13:57 tgl Exp $
*
*-------------------------------------------------------------------------
*/
@@ -2435,7 +2435,10 @@ numeric_stddev_internal(ArrayType *transarray,
}
else
{
- mul_var(&vN, &vNminus1, &vNminus1, 0); /* N * (N - 1) */
+ if (sample)
+ mul_var(&vN, &vNminus1, &vNminus1, 0); /* N * (N - 1) */
+ else
+ mul_var(&vN, &vN, &vNminus1, 0); /* N * N */
rscale = select_div_scale(&vsumX2, &vNminus1);
div_var(&vsumX2, &vNminus1, &vsumX, rscale, true); /* variance */
if (!variance)