PL/SQL常用表达式及举例(一)
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常用表达式及举例(一)的更多相关文章
- PL/SQL常用表达式及举例(二)
使用LOOP循环 declare v_i number:=1; begin loop dbms_output.put_line('v_i='||v_i); exit when v_i>=3; v ...
- PL/SQL常用语法及举例
PLSQL语句 DECLARE 声明部分 BEGIN 程序编写,SQL语句 EXECPTION 处理异常 END; / 声明部分(DECLARE) SQL> set serveroutput o ...
- PL/SQL常用设置 可看引用位置更清晰直观 引自:http://blog.csdn.net/xiaoqforever/article/details/27695569
引自:http://blog.csdn.net/xiaoqforever/article/details/27695569 1,登录后默认自动选中My Objects 默认情况下,PLSQL Deve ...
- oracle入门(6)——PL/SQL常用语法
[本文介绍] 本文不是”语法大全“,只是记录下作项目里自己常用的一些语法.方便查询. [语法] [输出] (1)输出语法 DBMS_OUTPUT.PUT_LINE( ) [定义] (1)定义变 ...
- PL/SQL常用设置
tools-->preferences-->user interface-->editor-->AutoReplace AutoReplaceWhen enabled, you ...
- PL/SQL设置快捷键
PL/SQL常用的快捷方式: sf= select * from sr=select t.*,t.rowid from t sd = select distinct * from d=delete f ...
- Oracle 11g系列:SQL Plus与PL/SQL
SQL Plus是Oracle提供的一种用户接口,是数据库与用户之间进行交互的工具. PL/SQL是Oracle的过程化编程语言. 1.登录SQL Plus 利用Windows的[开始]|[运行]命令 ...
- PL/SQL块与表达式
一.块(Block) 是PL/SQL的基本执行单元,由定义部分,执行部分(必须)和例外处理部分组成. Declare /*定义部分――定义常量.变量.游标.例外.复杂数据类型*/ Begin /*执行 ...
- 常用的PL/SQL开发原则
(1)广泛使用绑定变量,特别是批量绑定,因为这可以有效的避免sql的硬解析和PL/SQL引擎和SQL引擎的上下文切换!(2)广泛使用UROWID来处理DML语句(UROWID是ROWID扩展,ORAC ...
随机推荐
- Splash 对象方法
go() wait() jsfunc() evaljs() runjs() autoload() call_later() http_get() http_post() set_content() h ...
- 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: ...
- Expected BEGIN_ARRAY but was BEGIN_OBJECT
Expected BEGIN_ARRAY but was BEGIN_OBJECT at line 1 column 3519 path $.data[1].inspector_user Gson 中 ...
- codeforces水题100道 第十八题 Codeforces Round #289 (Div. 2, ACM ICPC Rules) A. Maximum in Table (brute force)
题目链接:http://www.codeforces.com/problemset/problem/509/A题意:f[i][1]=f[1][i]=1,f[i][j]=f[i-1][j]+f[i][j ...
- iOS - 白名单应用间相互跳转
1. 应用间相互跳转简介 在iOS开发的过程中,我们经常会遇到需要从一个应用程序A跳转到另一个应用程序B的场景.这就需要我们掌握iOS应用程序之间的相互跳转知识. 下面来看看我们在开发过程中遇到的应用 ...
- 在MyEclipse(2015)中上传项目到github的步骤(很详细)
(图文)在MyEclipse(2015)中上传项目到github的步骤(很详细) git|smartGit使用详解 SmartGit使用教程
- linux下删除大量小文件
当目录下文件太多时,用rm删除文件会报错:-bash: /bin/rm: Argument list too long提示文件数目太多.解决的办法是使用如下命令:ls | xargs -n 10 rm ...
- php 原生文件下载
1.整个网页的html界面源码下载: xiazai.php <html> <head> <meta charset ="utf-8"> < ...
- sqlserver添加查询 表、字段注释(转)
环境:xp sp3,sql server2008 .sqlserver用语句给表注释 EXECUTE sp_addextendedproperty N'MS_Description', N'表注释', ...
- 【JSON.NET】json序列化小驼峰格式(属性名首字母小写)
废话少说,先上代码 var setting = new JsonSerializerSettings { ContractResolver = new Newtonsoft.Json.Serializ ...