我在the documentation中看不到;它可能是我没有注意到的现有功能的一部分,还是以其他方式可用?
此功能在您发送的官方文档中不存在,因此可能仍然不存在。如果您需要类似的东西,则可能应该以编程方式自己计算标准偏差。您拥有AVG function,可以帮助您至少获得中位数,这将对标准偏差的计算有所帮助,并且COUNT函数可用于输入条目数。
double standardDeviation ; // standard deviation
double sumOfDiffrences = 0;
for ( int i = 0; i < count; i++ ){
sumOfDiffrences = sumOfDiffrences + pow((entry(i)-avg),2); // entry(i) is an entry of the column you want to create the S.D.
}
standardDeviation = sqrt((sumOfDiffrences)/(count-1));
如Andrei Tigau所述,尚不支持STDDEV。也就是说,您需要分两次计算。假设您对YourTable的x栏感兴趣,
SELECT SQRT(SUM(POW(x - avg, 2)/(n-1)))
FROM (SELECT AVG(x) AS avg, COUNT(*) AS n FROM YourTable)
CROSS JOIN YourTable;
您也可以尝试采用一种解决方案。
SELECT SQRT(s2/(n-1) - POW(s/n, 2))
FROM (
SELECT COUNT(*) AS n, SUM(x) AS s, SUM(x*x) AS s2
FROM YourTable
);
取决于类型,您可能必须将其强制转换为两倍(尤其是s2),以避免溢出。两者都将遭受浮点错误。