Loading...
  所在位置:论坛首页 -> ┈┋电脑网络技术区┋┈ -> 数据库技术 -> 用一个实例讲解Oracle数据库的PL/SQL语句块
标题:用一个实例讲解Oracle数据库的PL/SQL语句块收藏 编辑 删除 楼主 | 上一篇 下一篇
柔情浪子
等级:社区游侠
权限:普通用户
积分:41
金钱:721
声望:48
经验:48
发帖数:185
注册:2008年2月16日
资料 短消息2008-8-2 10:34:10

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;

2008-8-2 10:34:10 顶部
第1页 共页 共0个回复     <<    >>    
 快速回复
  • 支持UBB,HTML标签

  • 高级回复

  • 操作选项:评分 加精 解精 奖惩 设专题 设公告 解公告 固顶 总固顶 解固顶 结帖 解结帖 锁帖 解锁 移帖 删帖
      首页 | 购买指南 | 商业版本 | 虚拟主机 | 特色介绍 | 下载中心 | 支付方式
    Copyright 2004-2008 BBSGood.com Powered By: BBSGood.Speed Version 5.0
      咨询电话:0575-85513832、0575-85513825(传真)、7*24小时咨询服务:13606552007 不良信息举报中心 浙ICP备05029817号
      业务QQ:38958768、客服QQ1:415896239、客服QQ2:343896043、MSN:jccsxx@hotmail.com