用一个实例讲解Oracle数据库的PL/SQL语句块

来源:未知 责任编辑:责任编辑 发表时间:2015-09-09 15:36 点击:

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;

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • 在oracle数据库下使用iSQL*Plus DBA访问数据库
    • oracle 让sys用户可以使用isqlplus
    • Oracle数据库Constraint约束的常用操作及异常处理
    • ORACLE10gr2数据导入MySQL方案
    • OCP043第十五讲 Database Security
    • export/import的使用
    • Oracle行列转换小结
    • Table函数使用简介
    • Bulk Collect性能分析(zz)
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1