Mysql
 sql >> Base de données >  >> RDS >> Mysql

MySQL Math - Est-il possible de calculer une corrélation dans une requête ?

Voici une mise en œuvre approximative de l'exemple de coefficient de corrélation tel que décrit dans :

Wikipedia - Corrélation et dépendance

create table sample( x float not null, y float not null );
insert into sample values (1, 10), (2, 4), (3, 5), (6,17);

select @ax := avg(x), 
       @ay := avg(y), 
       @div := (stddev_samp(x) * stddev_samp(y))
from sample;

select sum( ( x - @ax ) * (y - @ay) ) / ((count(x) -1) * @div) from sample;
+---------------------------------------------------------+
| sum( ( x - @ax ) * (y - @ay) ) / ((count(x) -1) * @div) |
+---------------------------------------------------------+
|                                       0.700885077729073 |
+---------------------------------------------------------+