左连接生成奖金表,然后筛选出有奖金的员工

1、左连接生成奖金表,left join;
2、筛选出有奖金的员工,btype > 0 ,注意有默认值,btype 是none 值不是null值。
select 
e.emp_no
,e.first_name
,e.last_name
,b.btype
,s.salary
,round(s.salary * b.btype / 10,1) bonus -- round 函数四舍五入返回一位小数
from employees e
left join emp_bonus b
on e.emp_no = b.emp_no
left join ( -- 左连接生成奖金表
    select 
    emp_no
    ,salary
    from salaries
    where to_date = '9999-01-01'
          ) s
on s.emp_no = e.emp_no

where b.btype > 0 -- 有奖金的人btype>0,注意不是null值
order by e.emp_no