2016-05-26 10 views
-1

私は2つのテーブルを最初にemp(emp_id、name、gender - MまたはF)、2番目をemp_sal(emp_id、住所、給与)とします。女性従業員は10%をインクリメントする必要があり、男性従業員は現在の給与の15%をontherテーブルの給与基盤を更新する

答えて

-1
DECLARE 
CURSOR cur_emp 
IS 
SELECT * FROM emp; 
rec_emp cur_emp%rowtype; 
BEGIN 
    OPEN cur_emp; 
    LOOP 
FETCH cur_emp INTO rec_emp; 
EXIT WHEN cur_emp%notfound; 
IF rec_emp.gender = 'F'THEN 
    UPDATE emp_sal SET sal = sal + (sal * 0.1) WHERE emp_id = rec_emp.emp_id; 
elsif rec_emp.GENDER = 'M' THEN 
    UPDATE emp_sal SET sal = sal + (sal * 0.15) WHERE emp_id = rec_emp.emp_id; 
END IF; 
END LOOP; 
CLOSE cur_emp; 
0

私たちは、以下のクエリを使用して試すことができます.....インクリメントされなければならない

UPDATE empd es set es.E_salary=case 
when(select eg.gender from emps eg where eg.empid=es.empid)='M' 
THEN 
es.E_salary*0.1 
else 
es.E_salary*0.5 
end; 
関連する問題