mysq查询员工姓名,入职时间,入职天数,原始工资,现工资cur_salary(如果入职天数大于2000的工资*1.5,入职天数大于1600的工资*1.4,入职天数大于1200的工资*1.3,入职

查询员工工资的最大值,最小值,平均值,总和,四舍五入保留两位小数

查询部门编号为3的员工数,即部门3有多少名员工

查询入职时间最早和最晚的员工相差天数

查询员工姓名,入职时间,入职天数,原始工资,现工资cur_salary(如果入职天数大于2000的工资*1.5,

入职天数大于1600的工资*1.4,入职天数大于1200的工资*1.3,入职天数大于1000的工资*1.2,其他的显示原工资)

-- 查询员工工资的最大值,最小值,平均值,总和,四舍五入保留两位小数
SELECT TRUNCATE(MAX(salary),2),TRUNCATE(MIN(salary),2),TRUNCATE(AVG(salary),2),TRUNCATE(SUM(salary),2) FROM emplyees
-- 
-- 查询部门编号为3的员工数,即部门3有多少名员工
-- 
SELECT count(*) 总数 FROM emplyees where department_id=3

-- 查询入职时间最早和最晚的员工相差天数
--
SELECT DATEDIFF(MAX(hiredate),MIN(hiredate) ) 相差天数 FROM emplyees 
-- 查询员工姓名,入职时间,入职天数,原始工资,现工资cur_salary(如果入职天数大于2000的工资*1.5,
-- 


SELECT emplyee_name, hiredate, DATEDIFF(NOW(), hiredate), salary,
    CASE 
        WHEN DATEDIFF(NOW(), hiredate) > 2000 THEN salary * 1.5
        ELSE salary		
    END AS cur_salary
FROM emplyees;
-- 入职天数大于1600的工资*1.4,入职天数大于1200的工资*1.3,入职天数大于1000的工资*1.2,其他的显示原工资)
-- 


SELECT *, DATEDIFF(NOW(), hiredate)  ,
    CASE 
        WHEN DATEDIFF(NOW(), hiredate) > 1600 THEN salary * 1.4
        WHEN DATEDIFF(NOW(), hiredate) > 1200 THEN salary * 1.2
        ELSE salary
    END AS cur_salary
FROM emplyees;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值