解析Oracle的CORR分析函数

加入我们的微信群,你将获得不仅仅是知识,还能享受免费最新GPT-4o模型微信机器人+Oracle MOS免费查询+职业发展规划咨询+数据库大佬交流,很多志同道合的小伙伴,欢迎加群一起探讨、学习、进步!“选择”比“努力”更重要。扫描下方二维码添加作者微信,回复“DBA理想”即可开启你的数据库学习之旅。解析Oracle的CORR分析函数-每日运维


解析Oracle的CORR分析函数-2

解析Oracle的CORR分析函数-每日运维

引言

解析Oracle的CORR分析函数-每日运维

在数据分析中,了解变量之间的相关性至关重要。而 Oracle 提供的 CORR 分析函数正是用于计算变量间相关性的强大工具。本文将详细解析 Oracle 中的 CORR 分析函数,帮助您更好地理解和应用它。


解析Oracle的CORR分析函数-每日运维

CORR 函数简介

解析Oracle的CORR分析函数-每日运维

CORR 函数用于计算两个变量之间的皮尔逊相关系数。皮尔逊相关系数值介于 -1 和 +1 之间,表示变量之间的线性关系:

  • +1:完全正线性相关。一个变量增加,另一个变量也按比例增加。

  • 0:无线性相关。变量之间没有线性关系。

  • -1:完全负线性相关。一个变量增加,另一个变量按比例减少。


解析Oracle的CORR分析函数-每日运维

创建测试用例

解析Oracle的CORR分析函数-每日运维

需要一张示例表来进行演示:

    CREATE TABLE emp ( empno NUMBER(4) CONSTRAINT pk_emp PRIMARY KEY, ename VARCHAR2(10), job VARCHAR2(9), mgr NUMBER(4), hiredate DATE, sal NUMBER(7,2), comm NUMBER(7,2), deptno NUMBER(2));INSERT INTO emp VALUES (7369,'SMITH','CLERK',7902,to_date('1980-12-17','yyyy-mm-dd'),800,NULL,20);INSERT INTO emp VALUES (7499,'ALLEN','SALESMAN',7698,to_date('1981-02-20','yyyy-mm-dd'),1600,300,30);INSERT INTO emp VALUES (7521,'WARD','SALESMAN',7698,to_date('1981-02-22','yyyy-mm-dd'),1250,500,30);INSERT INTO emp VALUES (7566,'JONES','MANAGER',7839,to_date('1981-04-02','yyyy-mm-dd'),2975,NULL,20);INSERT INTO emp VALUES (7654,'MARTIN','SALESMAN',7698,to_date('1981-09-28','yyyy-mm-dd'),1250,1400,30);INSERT INTO emp VALUES (7698,'BLAKE','MANAGER',7839,to_date('1981-05-01','yyyy-mm-dd'),2850,NULL,30);INSERT INTO emp VALUES (7782,'CLARK','MANAGER',7839,to_date('1981-06-09','yyyy-mm-dd'),2450,NULL,10);INSERT INTO emp VALUES (7788,'SCOTT','ANALYST',7566,to_date('1987-04-19','yyyy-mm-dd')-85,3000,NULL,20); -- 1987-07-13 减去85天INSERT INTO emp VALUES (7839,'KING','PRESIDENT',NULL,to_date('1981-11-17','yyyy-mm-dd'),5000,NULL,10);INSERT INTO emp VALUES (7844,'TURNER','SALESMAN',7698,to_date('1981-09-08','yyyy-mm-dd'),1500,0,30);INSERT INTO emp VALUES (7876,'ADAMS','CLERK',7788,to_date('1987-05-23','yyyy-mm-dd')-51,1100,NULL,20); -- 1987-07-13 减去51天INSERT INTO emp VALUES (7900,'JAMES','CLERK',7698,to_date('1981-12-03','yyyy-mm-dd'),950,NULL,30);INSERT INTO emp VALUES (7902,'FORD','ANALYST',7566,to_date('1981-12-03','yyyy-mm-dd'),3000,NULL,20);INSERT INTO emp VALUES (7934,'MILLER','CLERK',7782,to_date('1982-01-23','yyyy-mm-dd'),1300,NULL,10);COMMIT;