PL/SQL程序塊以顯示所給出雇員編號的雇員的詳細(xì)信息
1 SQL> Declare
2 v_empno emp.empno%Type; /*聲明變量v_empno,%type:使該變量的類型與emp表中的empno類型相同*/
3 v_emPRecord emp%Rowtype;/*聲明變量v_emprecord,%rowtype:使該變量的類型與emp表中的整行相同*/
4 Begin
5 Select * Into v_emprecord From emp Where empno=&v_empno;
6 dbms_output.put_line('雇員編號'||v_emprecord.empno);
7 dbms_output.put_line('雇員姓名'||v_emprecord.ename);
8 dbms_output.put_line('入職日期'||v_emprecord.hiredate);
9 dbms_output.put_line('職位'||v_emprecord.job);
10 dbms_output.put_line('管理員編號'||v_emprecord.mgr);
11 dbms_output.put_line('工資'||v_emprecord.sal);
12 dbms_output.put_line('獎金'||v_emprecord.comm);
13 dbms_output.put_line('部門編號'||v_emprecord.deptno);
14 End;
if條件控制語句
語法:
1 if condition then statement;
2 elsif condition then statement;
3 else statement;
4 end if;
5/*condition 是一個布爾變量(值為true,false 或null,當(dāng)表達(dá)式為true是執(zhí)行then);statement是PL/SQL 或SQL 語句;*/
通過if-then-elsif,按下列加薪比執(zhí)行:(加薪的百分比是以他們現(xiàn)有的薪水為根據(jù)的)
Deptno Raise(%age)
10 5%
20 10%
30 15%
40 20%
1 SQL> Declare
2 v_empno emp.empno%Type;
3 v_emprecord emp%Rowtype;
4 v_sal emp.sal%Type;
5 Begin
6 Select * Into v_emprecord From emp Where empno=&v_empno;
7 If v_emprecord.empno='10' Then v_sal:=v_emprecord.sal*1.05;
8 Elsif v_emprecord.empno='20' Then v_sal:=v_emprecord.sal*1.10;
9 Elsif v_emprecord.empno='30' Then v_sal:=v_emprecord.sal*1.15;
10 Elsif v_emprecord.empno='40' Then v_sal:=v_emprecord.sal*1.20;
11 End If;
12 End;
for loop循環(huán)控制語句語法:
1for counter in [reverse] lower_bower..upper_bound loop
2statement1;
3statement2;
4
5end loop;
6/*counter 是一個隱式聲明的整數(shù),每次循環(huán)一次其自增1或自減1; reverse 將counter 從最大值每次減1至最小值; lower_bound 指定counter 變量變化范圍的下屆 upper_bound 指定counter 變量變化范圍的上屆*/
利用for loop 循環(huán)控制語句實現(xiàn)向"emp"表添加10個新雇員編號;
1 SQL> Declare
2 v_empno emp.empno%Type;
3 Begin
4 Select Max(empno) Into v_empno From emp;
5 For i In 1..10 Loop
6 v_empno:=v_empno+1;
7 Insert Into emp (empno) Values (v_empno);
8 End Loop;
9 End;
新聞熱點
疑難解答
圖片精選