1.基本的if else

DECLARE
I INT :=1;
BEGIN
IF I=1 THEN
DBMS_OUTPUT.PUT_LINE('TRUE');
ELSE
DBMS_OUTPUT.PUT_LINE('FALSE');
END IF; END;

2.这里用的是elsif 而不是 else if(注意区分一下就行了)

DECLARE
I INT :=1; --如果I=1 满足第一个条件之后,就不会再走第二个条件
--如果I=5,则直接走最后的一个条件
BEGIN
IF I<4 THEN
DBMS_OUTPUT.PUT_LINE('');
ELSIF I<3 THEN
DBMS_OUTPUT.put_line('');
ELSIF I<2 THEN
DBMS_OUTPUT.PUT_LINE('');
ELSE
DBMS_OUTPUT.PUT_LINE('');
END IF;
END;

3.decode语法

--DECODE('条件',值1,真,假)
--简单实例一 SELECT DECODE((2-2),0,'TRUE','FALSE') FROM DUAL; --结果返回true --简单实例二;比较两个数的大小;
--先介绍一函数的使用sign() 它只会返回三个值:1 0 -1 SELECT SIGN(2-1) FROM DUAL; --正数就返回1 SELECT SIGN(2-2) FROM DUAL; --0 就返回0 SELECT SIGN(2-3) FROM DUAL; --负数就返回-1 --然后配合它 我们可以比较两个数的大小滴呀 DECLARE
I INT :=2;
J INT :=3;
RESULT INT :=0;
BEGIN
SELECT DECODE(SIGN(I-J),-1,I,J) INTO RESULT FROM DUAL; --比较连个数,求最小或者最大的数
DBMS_OUTPUT.put_line(RESULT); --这样我们就求出了最小的一个数值滴呀
END; --实例三(字段)
DECLARE
NAME VARCHAR2(99) :='DD';
RESULT VARCHAR2(99) ;
BEGIN
SELECT DECODE(NAME,'JACK','JACK','TOM','TOM','DEFAULUT') INTO RESULT FROM DUAL;
--第一个参数值 也可以是我们的字段;
--字段,比较,值1,比较,值2,默认值
--进行这样的基本模式比较低呀
DBMS_OUTPUT.put_line(RESULT);
END;

DECODE的应用 ,下面我们看这样的一个需求;

CREATE TABLE STUINFO(
ID NUMBER,
NAME VARCHAR2(40),
SEX VARCHAR2(4)
) INSERT INTO STUINFO VALUES(1,'JACK','男'); INSERT INTO STUINFO VALUES(2,'TOM','男'); INSERT INTO STUINFO VALUES(3,'ANDY','女'); INSERT INTO STUINFO VALUES(4,'CANDY','女'); COMMIT; --现在我们来统计班上 男生多少人,女生多少人;
--方法一;
SELECT COUNT(*) FROM STUINFO WHERE SEX='男'; SELECT COUNT(*) FROM STUINFO WHERE SEX='女'; --方法二;(如果id没有重复的话)
--我们再求一次和
--方法虽然有点绕弯,但是可以锻炼我们写sql语句的能力滴呀
SELECT SUM(MEN_COUNT) "男生总和",SUM(FEMEL_COUNT) "女生总和" FROM (
SELECT ID,
SUM(CASE SEX WHEN '男' THEN 1 ELSE 0 END) "MEN_COUNT",
SUM(CASE SEX WHEN '女' THEN 1 ELSE 0 END) "FEMEL_COUNT"
FROM STUINFO
GROUP BY ID
) --方法三,自然就用到我们的DECODE
--这样用起来的 相当的方便
SELECT SUM(DECODE(SEX,'男',1,0)) "MEN_TOTAL", SUM(DECODE(SEX,'女',1,0)) "女生总和" FROM STUINFO

4.case when 的用法

关于学生等级的分法;

--关于学生成绩 分等级的计算滴呀
--CASE WHEN 字段 THEN 的用法;
SELECT NAME,
CASE WHEN GREADE >85 THEN '优秀'
WHEN GREADE >70 THEN '良好'
WHEN GREADE >60 THEN '及格'
ELSE '不及格'
END "等级"
FROM STU --然后是我们DEcode 的使用方法滴呀 SELECT NAME, DECODE(SIGN(GREADE-85),1,'优秀',0,'优秀',-1,
DECODE(SIGN(GREADE-70),1,'良好',0,'良好,-1',
DECODE(SIGN(GREADE-60),1,'及格',0,'及格',-1,'不及格')
)) "等级"
FROM STU

oracle 条件语句的写法的更多相关文章

  1. mybatis中Oracle分页语句的写法

    最近一段时间使用oracle数据库查询分页, 用的是springboot. Oracle数据库中没有像mysql中limit的写法, 只能换其他方式写. 考虑到oracle中的ROWNUM变量, 使用 ...

  2. 很多人不知道的Python 炫技操作:条件语句的写法

    有的人说 Python 是一门 入门容易,但是精通难的语言,这一点我非常赞同. Python 语言里有许多(而且是越来越多)的高级特性,是 Python 发烧友们非常喜欢的.在这些人的眼里,能够写出那 ...

  3. 【Python】解析Python中的条件语句和循环语句

    1.if语句 if语句有好几种格式,比如: if condition: statement 使用 if ... else ...: if condition: statement(1) else: s ...

  4. Python趣味入门4:选择往往是最重要的-条件语句

    人生处处有选择,程序也有选择,为了让程序变得更加强壮,程序员必须考虑任何情况,上一篇了解到了如何使用Python来行顺序语句的编写,我们写了一个可以输入姓名的生日祝贺程序,今天我们挑战条件语句! 1. ...

  5. Oracle分页查询语句的写法(转)

    Oracle分页查询语句的写法(转)   分页查询是我们在使用数据库系统时经常要使用到的,下文对Oracle数据库系统中的分页查询语句作了详细的介绍,供您参考. Oracle分页查询语句使我们最常用的 ...

  6. Oracle把逗号分割的字符串转换为可放入in的条件语句的字符数列

    Oracle把逗号分割的字符串转换为可放入in的条件语句的字符数列   前台传来的字符串:'589,321' SELECT*FROM TAB_A T1 WHERE  T1.CODE  IN ( SEL ...

  7. Oracle中分页查询语句的写法

    要动态的变化分页查询的条件,比如pageNow 这个变量表示的是当前是第几页, oracle分页有通用写法,假设一页5行 select * from ( select t.*,rownum rn fr ...

  8. oracle高性能的SQL语句的写法

    1.当多表查询的时候,把数据量小的表放在最后面,ORACLE会把最后面的表当作基础表,因为表间连接时,最右边的表会被放到嵌套循环的最外层.最外层的循环次数越少,效率越高. 2.Oracle采用自下而上 ...

  9. Oracle的存储过程基本写法

    转: Oracle的存储过程基本写法 目录 1.1,Oracle存储过程简介: 1.2,创建存储过程的语法: 2.0,游标的使用.看到的一段解释很好的概念,如下: 回到顶部 1.1,Oracle存储过 ...

随机推荐

  1. POJ 1734 Sightseeing trip(无向图最小环+输出路径)

    题目链接 #include <cstdio> #include <string> #include <cstring> #include <queue> ...

  2. Get the image file(s) some informations,Including the Make,Model,Date/Time,etc

    This is a blog about how to get the image file(s) some informations.Including the Make,Model,Date/Ti ...

  3. 3.22学习理解httpContext与where 1=1

    1.HttpContextHttpContext.Current.Session.RemoveAll();从会话状态集合中移除所有的键和值.(未过期,还存在)HttpContext.Current.S ...

  4. Camera Calibration and 3D Reconstruction

    3D RECONSTRUCTION WITH OPENCV AND POINT CLOUD LIBRARY http://stackoverflow.com/questions/19205557/op ...

  5. python表达式

    算术表达式: 地板除: >>> 10 // 3 3>>> 5 // 2 2>>> 5 // 31 取余: >>> 10 % 31 ...

  6. virt-manage图形界面键盘错位问题

    键盘错乱问题: 启动引导问题:

  7. http页面转发和重定向的区别

    一.调用方式 我们知道,在servlet中调用转发.重定向的语句如下:request.getRequestDispatcher("new.jsp").forward(request ...

  8. 随机(Random)

    随机(Random)随机是智能的基础,人工智能的很多技术都需要用到随机,因此有必要把这个提到前面谈谈一考虑基于C/C++,般我们都是使用的rand ()等函数实现随机,当然我们也有吊炸天的boost库 ...

  9. Visual Studio开发环境最佳字体及配色

    环境: Visual Studio 2010,(本人使用的windows 7) 字体:Fixedsys, 12pt,下载地址:http://www.fixedsysexcelsior.com 普通文本 ...

  10. 区分super和this

    Java关键字this.super使用总结 一.this Java关键字this只能用于方法方法体内.当一个对象创建后,Java虚拟机(JVM)就会给这个对象分配一个引用自身的指针,这个指针的名字就是 ...