一个关于检索薪水高于部门平均值的sql文

DROP TABLE IF EXISTS `EMPLOYEESALARY`

CREATE TABLE `EMPLOYEESALARY` (
`ID` INT(5) NOT NULL AUTO_INCREMENT COMMENT 'PRIMARY KEY',
`NAME` VARCHAR(20) NOT NULL,
`SALARY`  FLOAT(8),
`DEPARTMENT` VARCHAR(20),
PRIMARY KEY(`ID`)
)ENGINE MYISAM DEFAULT CHARSET=utf8 COMMENT 'EMPLOYEE TABLE';

SELECT `ID`,`NAME` FROM `EMPLOYEESALARY` AS TABLE1
LEFT JOIN
( SELECT `DEPARTMENT`,AVG(`SALARY`) AS SALARY FROM `EMPLOYEESALARY` GROUP BY `DEPARTMENT` ) AS TABLE2
ON TABLE1.`DEPARTMENT` = TABLE2.`DEPARTMENT`
WHERE TABLE1.`SALARY` >= TABLE2.`SALARY`;
<span style="font-family: Arial, Helvetica, sans-serif;">mysql的存储过程实现,mysql中没有像oracle中的%rowtype</span>
 
DELIMITER $$

CREATE PROCEDURE `test`.`SalaryCalcProc`()
    BEGIN
	#部门名
	DECLARE DEPARTMENT1 VARCHAR(20);
	#薪水
	DECLARE SALARY1 FLOAT(8);
	#关于部门平均薪水的游标
	DECLARE DESTCURSOR CURSOR FOR SELECT `DEPARTMENT`,AVG(`SALARY`) FROM `EMPLOYEESALARY` GROUP BY `DEPARTMENT`;
	
	#打开游标
	OPEN DESTCURSOR;
	
	#循环游标
	READ_LOOP:LOOP
	  #读取游标值
	  FETCH DESTCURSOR INTO DEPARTMENT1,SALARY1;
		
	  IF FALSE THEN
	    LEAVE READ_LOOP;
	  END IF;
	  #检索出高于部门平均薪水的职员
	  SELECT * FROM `EMPLOYEESALARY` WHERE SALARY >= SALARY1 AND DEPARTMENT = DEPARTMENT1;
	  
	END LOOP;
    END$$

DELIMITER ;


 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chenjian0415

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值