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. BZOJ4009: [HNOI2015]接水果

    4009: [HNOI2015]接水果 Description 风见幽香非常喜欢玩一个叫做 osu!的游戏,其中她最喜欢玩的模式就是接水果. 由于她已经DT FC 了The big black,  她 ...

  2. Linux 高级网络编程

    设置套接字函数: #include<sys/socket.h> int setsockopt(int sockfd, int level, int optname, const void* ...

  3. 使用ProxychainsMac下安装及配置

    下面几种解决方式 一.先在VPS用composer把Laravel给拖回来,本地你就别想用Composer正常下载Laravel回来了 二.使用全局代理,暂时木有折腾过在终端下怎么折腾,GUI可以使用 ...

  4. PTF 安装及简单测试 Packet Testing Framework

    PTF PTF is a Python based dataplane test framework. It is based on unittest, which is included in th ...

  5. The P4 Language Specification v1.0.2 Parser

    <p4规范>解析器部分详解 p4解析器是根据有限状态机的思想来设计的. 解析器中解析的过程可以被一个解析图(parser graph)所表示,解析图中所表示的某一个状态(或者说,在P4语言 ...

  6. Redis 笔记与总结8 PHP + Redis 信息管理系统(分页+好友关注)

    分页 要对列表页进行分页,需要知道: ①用户总数 $count ② 页大小 $pageSize:用户自定义 ③ 当前页:$page:GET 方式获取 ④ 总页数:$pageCount = ceil($ ...

  7. PHP 错误与异常 笔记与总结(8)自定义错误处理函数 set_error_handler()

    通过 Set_error_handler() 函数设置用户自定义的错误处理函数. 步骤: ① 创建错误处理函数 ② 设置不同级别调用函数 ③ Set_error_handler() 函数制定接管错误处 ...

  8. ecshop 工作流程加载配置介绍

    ecshop 工作流程加载配置介绍 分类: ecshop2014-09-14 09:36 729人阅读 评论(2) 收藏 举报 模板引擎工作流 这里简单介绍下echsop工作流程: 首先,你会发现一般 ...

  9. javascript Math.pow 函数 详解

    语法 Math.pow(x,y) 定义和用法 pow() 方法可返回 x 的 y 次幂的值. 处理简单数学问题 6的4次方等于1296,记作:64=1296; 求值: Math.pow(6,4)=12 ...

  10. REST性能测试方案

    1.REST简介 REST(代表性状态传输,Representational State Transfer)是一种Web服务设计模型.REST定义了一组体系架构原则,您可以根据这些原则设计以系统资源为 ...