IF 判断条件 THEN 满足条件时执行语句 END IF;

DECLARE

v_countResult NUMBER;

BEGIN

SELECT COUNT(empno) INTO v_countResult FROM emp;

IF v_countResult>10 THEN

DBMS_OUTPUT.put_line(v_countResult);

END if;

END;

/

IF 判断条件 THEN 满足条件时执行语句 ELSE 不满足条件时执行的语句 END IF;

DECLARE

v_countResult NUMBER;

BEGIN

SELECT COUNT(deptno) INTO v_countResult FROM dept;

IF v_countResult>10 THEN

DBMS_OUTPUT.put_line('DEPT>10');

ELSE

DBMS_OUTPUT.put_line('DEPT<10');

END IF;

END;

/

IF 判断条件1 THEN 满足条件1时执行的语句 ELSE IF 满足条件2时执行的语句ELSE所有条件都不满足时执行的语句 END IF;

DECLARE

v_countResult NUMBER;

BEGIN

SELECT COUNT(deptno) INTO v_countResult FROM dept;

IF v_countResult>10 THEN

DBMS_OUTPUT.put_line('DEPT>10');

ELSIF v_countResult<10 THEN

DBMS_OUTPUT.put_line('DEPT<10');

ELSE

DBMS_OUTPUT.put_line('DEPT=10');

END IF;

END;

/

查询EMP表的工资,输入员工编号,根据编号查询工资,如果工资高于3000元,则显示高工资,如果工资大于2000元,则显示中等工资,如果工资小于2000元,则显示低工资。

DECLARE

v_eno NUMBER;

v_sal NUMBER;

v_ename emp.ename%TYPE;

BEGIN

v_eno:=&empno;

SELECT ENAME,SAL INTO v_ename,v_sal from emp where empno=v_eno;

IF v_sal >3000 THEN

DBMS_OUTPUT.put_line(v_ename||' High salary');

ELSIF v_sal>2000 THEN

DBMS_OUTPUT.put_line(v_ename||' medium salary');

ELSE

DBMS_OUTPUT.put_line(v_ename||' low salary');

END IF;

END;

/

查询员工年薪

DECLARE

v_eno NUMBER;

v_sal emp.sal%TYPE;

v_ename emp.ename%TYPE;

BEGIN

v_eno:=&empno;

SELECT ENAME,SAL INTO v_ename,v_sal from emp where empno=v_eno;

DBMS_OUTPUT.put_line(v_ename||'''s annual salary is '||12*v_sal);

END;

/

用户输入一个雇员编号,根据它所在的部门给上涨工资,规则:10部门上涨10%,20上涨20%,30上涨30%,但是要求最高不能超过5000,超过5000就停留在5000.

我的写法

DECLARE

v_eno emp.empno%TYPE;

v_ename emp.ename%TYPE;

v_sal emp.sal%TYPE;

v_deptno emp.deptno%TYPE;

BEGIN

v_eno:=&empno;

SELECT DEPTNO,ENAME,SAL INTO v_deptno,v_ename,v_sal FROM EMP WHERE EMPNO=v_eno;

IF v_deptno=10 and 1.1*v_sal<5000 THEN

DBMS_OUTPUT.put_line(v_ename||','||1.1*v_sal);

ELSIF v_deptno=20 and 1.2*v_sal<5000 THEN

DBMS_OUTPUT.put_line(v_ename||','||1.2*v_sal);

ELSIF v_deptno=30 and 1.3*v_sal<5000 THEN

DBMS_OUTPUT.put_line(v_ename||','||1.3*v_sal);

ELSE

DBMS_OUTPUT.put_line(v_ename||'5000');

END IF;

END;

写法2:

Declare

v_empsal emp.sal%TYPE;

v_dno emp.deptno%TYPE;

v_eno emp.empno%TYPE;

BEGIN

v_eno:=&empno;

Select deptno,sal into v_dno,v_empsal from emp where empno=v_eno;

If v_dno=10 then

If v_empsal*1.1>5000 then

Update emp set sal=5000 where empno=v_eno;

Else

Update emp set sal=sal*1.1 where empno=v_eno;

End if;

elsIf v_dno=20 then

If v_empsal*1.2>5000 then

Update emp set sal=5000 where empno=v_eno;

Else

Update emp set sal=sal*1.2 where empno=v_eno;

End if;

elsIf v_dno=30 then

If v_empsal*1.3>5000 then

Update emp set sal=5000 where empno=v_eno;

Else

Update emp set sal=sal*1.3 where empno=v_eno;

End if;

Else

Null;

End if;

End;

/

使用CASE进行多条件判断

declare

v_sal emp.sal%TYPE;

v_job emp.job%TYPE;

v_eno emp.empno%TYPE;

BEGIN

v_eno:=&empno;

SELECT SAL,JOB INTO v_sal,v_job from emp where empno=v_eno;

case

when v_job='CLERK' then

dbms_output.put_line(v_job||','||1.05*v_sal);

when v_job='SALESMAN' then

dbms_output.put_line(v_job||','||1.08*v_sal);

when v_job='MANAGER' then

dbms_output.put_line(v_job||','||1.10*v_sal);

when v_job='ANALYST' then

dbms_output.put_line(v_job||','||1.20*v_sal);

when v_job='PRESIDENT' then

dbms_output.put_line(v_job||','||v_sal);

else

null;

end case;

end;

/

PL/SQL常用表达式及举例(一)的更多相关文章

  1. PL/SQL常用表达式及举例(二)

    使用LOOP循环 declare v_i number:=1; begin loop dbms_output.put_line('v_i='||v_i); exit when v_i>=3; v ...

  2. PL/SQL常用语法及举例

    PLSQL语句 DECLARE 声明部分 BEGIN 程序编写,SQL语句 EXECPTION 处理异常 END; / 声明部分(DECLARE) SQL> set serveroutput o ...

  3. PL/SQL常用设置 可看引用位置更清晰直观 引自:http://blog.csdn.net/xiaoqforever/article/details/27695569

    引自:http://blog.csdn.net/xiaoqforever/article/details/27695569 1,登录后默认自动选中My Objects 默认情况下,PLSQL Deve ...

  4. oracle入门(6)——PL/SQL常用语法

    [本文介绍] 本文不是”语法大全“,只是记录下作项目里自己常用的一些语法.方便查询. [语法] [输出]   (1)输出语法 DBMS_OUTPUT.PUT_LINE( ) [定义]   (1)定义变 ...

  5. PL/SQL常用设置

    tools-->preferences-->user interface-->editor-->AutoReplace AutoReplaceWhen enabled, you ...

  6. PL/SQL设置快捷键

    PL/SQL常用的快捷方式: sf= select * from sr=select t.*,t.rowid from t sd = select distinct * from d=delete f ...

  7. Oracle 11g系列:SQL Plus与PL/SQL

    SQL Plus是Oracle提供的一种用户接口,是数据库与用户之间进行交互的工具. PL/SQL是Oracle的过程化编程语言. 1.登录SQL Plus 利用Windows的[开始]|[运行]命令 ...

  8. PL/SQL块与表达式

    一.块(Block) 是PL/SQL的基本执行单元,由定义部分,执行部分(必须)和例外处理部分组成. Declare /*定义部分――定义常量.变量.游标.例外.复杂数据类型*/ Begin /*执行 ...

  9. 常用的PL/SQL开发原则

    (1)广泛使用绑定变量,特别是批量绑定,因为这可以有效的避免sql的硬解析和PL/SQL引擎和SQL引擎的上下文切换!(2)广泛使用UROWID来处理DML语句(UROWID是ROWID扩展,ORAC ...

随机推荐

  1. Incorrect column count: expected 1, actual 5,JdbcTemplate queryForList 出错

    spring JdbcTemplate  queryForList 出错 Incorrect column count: expected 1, actual 5 >>>>&g ...

  2. mkubimage-mlc2: error while loading shared libraries: liblzo2.so.2: cannot open shared object file: No such file or directory

    mkubimage-mlc2: error while loading shared libraries: liblzo2.so.2: cannot open shared object file: ...

  3. Elasticsearch 版本控制

    悲观并发控制(Pessimistic concurrency control) 这在关系型数据库中被广泛的使用,假设冲突的更改经常发生,为了解决冲突我们把访问区块化.典型的例子是在读一行数据前锁定这行 ...

  4. 原:Myeclipse10+Egit+bitbucket实现版本控制

    1.首先在https://bitbucket.org注册账号,建立仓库(repository),这部分有问题的可以看https://confluence.atlassian.com/display/B ...

  5. WebService连接sql serever并使用Android端访问数据

    一.下载sql serever(真真难下) 建立数据库 二.创建WebService VS2015中新建项目,进行连接调试 1. 服务资源管理文件->数据连接->新建连接 2. 继续-&g ...

  6. Android 之 布局训练

      1.线性布局 LinearLayout <?xml version="1.0" encoding="utf-8"?> <LinearLay ...

  7. django进阶-modelform&admin action

    先看效果图: 登陆admin后的界面: 查看作者: 当然你也可以定制admin, 使界面更牛逼 数据库表结构: app01/models.py from django.db import models ...

  8. linux 文件编码问题

    iconv -f UTF- -t gb18030 file_input -o file_output 上述命令不一定有用. 大概了解下文件编码,和vim里面的编码情况. 1 字符编码基础知识 字符编码 ...

  9. Android调试技巧

    转自:http://gityuan.com/2017/07/11/android_debug/ 一. 获取Trace 调用栈信息(Trace)是分析异常经常使用的,这里简单划分两类情况: 当前线程Tr ...

  10. oracle dblink 查询 tns:无法解析指定的连接标识符

    问题情景是这样的:我在数据库服务器(windows server 2008r2 ,64bit)oracle(11gr2,64bit)中通过dblink连接到另外一台服务器(hp-ux)的oracle( ...