【赛迪网-it技术报道】pl/sql程序块以显示所给出雇员编号的雇员的详细信息
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,当表达式为true是执行then);statement是pl/sql 或sql 语句;*/
通过if-then-elsif,按下列加薪比执行:(加薪的百分比是以他们现有的薪水为根据的)
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循环控制语句语法:
1for counter in [reverse] lower_bower..upper_bound loop
2statement1;
3statement2;
4
5end loop;
6/*counter 是一个隐式声明的整数,每次循环一次其自增1或自减1; reverse 将counter 从最大值每次减1至最小值; lower_bound 指定counter 变量变化范围的下届 upper_bound 指定counter 变量变化范围的上届*/
利用for loop 循环控制语句实现向"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;
闽公网安备 35060202000074号