在实际开发中,经常会用到 if 和 case when的用法,记录一下,以后可以用得到.

DELIMITER $$

USE

`数据库`$$

DROPPROCEDUREIFEXISTS

`GetNoticemsg`$$

CREATE

DEFINER=`root`@`%`

PROCEDURE

`GetNoticemsg`(p_Id

VARCHAR

(64),p_InTime

DATETIME

,p_FunctionId

INT

,p_PersonType

INT

,p_GetType

INT

)

BEGIN

-- GetType 0:获取已发通知,1获取已收通知 -- PersonType 0:家长 1:老师

IF

(p_GetType=0)

THEN

-- 获取已经发送的

IF

(p_PersonType=1)

THEN

-- 如果是老师 (那么就是查询一张表就OK了,只需要查询主表)

CASEWHEN

p_FunctionId=101

THEN

-- 作业

SELECT

'这里写你的代码';

WHEN

p_FunctionId

IN

(102,103,105,106)

THEN

-- 多个情况用一个语句

SELECT

'这里写你的代码';

ENDCASE

; -- else -- 如果是家长,因为家长不可能发送任何通知,所以这里什么都不返回

ENDIF

; ELSEIF(p_GetType=1)

THEN

-- 获取已经收到的通知

IF

(p_PersonType=1)

THEN

-- 如果是老师,老师只能收到 通知老师103的通知,其他的都收不到

CASE

p_FunctionId

WHEN

103

THENSELECT

'这里写你的代码';

ENDCASE

;

ELSE

--

CASEWHEN

p_FunctionId=101

THENSELECT

'这里写你的代码';

WHEN

p_FunctionId

IN

(102,105,106)

THEN

-- 多个情况用一个语句

SELECT

'这里写你的代码';

ENDCASE

;

ENDIF

;

ENDIF

;

mysql if 和 case when 用法 多个when情况用一个语句 存储过程的更多相关文章

  1. oracle中DECODE与CASE的用法区别

    对于CASE与DECODE其实并没有太多的区别,他们都是用来实现逻辑判断.Oracle的DECODE函数功能很强,灵活运用的话可以避免多次扫描,从而提高查询的性能.而CASE是9i以后提供的语法,这个 ...

  2. MySQL中的case when 中对于NULL值判断的坑

    sql中的case when 有点类似于Java中的switch语句,比较灵活,但是在Mysql中对于Null的处理有点特殊 Mysql中case when语法: 语法1: CASE case_val ...

  3. Mysql coalesce()函数认识和用法

    Mysql coalesce()函数认识和用法   coalesce()解释:返回参数中的第一个非空表达式(从左向右):    鉴于在mysql中没有nvl()函数, 我们用coalesce()来代替 ...

  4. Oracle CASE WHEN 用法介绍

    1. CASE WHEN 表达式有两种形式 --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' END --Case搜索 ...

  5. mysql中INSTR函数的用法

    mysql中INSTR函数的用法 INSTR(字段名, 字符串) 这个函数返回字符串在某一个字段的内容中的位置, 没有找到字符串返回0,否则返回位置(从1开始) SELECT * FROM tblTo ...

  6. Oracle CASE WHEN 用法介绍[Z]

    Oracle CASE WHEN 用法介绍 1. CASE WHEN 表达式有两种形式 --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ...

  7. mysql语法之case when then与列转行

    mysql语法中case when then与列转行的使用场景非常丰富. case语句类似java中条件分支语句的作用,可以类比java中的switch语句或者if语句来学习. 其语法如下: case ...

  8. oracle case when 用法

    原文:http://www.cnblogs.com/eshizhan/archive/2012/04/06/2435493.html 1. CASE WHEN 表达式有两种形式 --简单Case函数 ...

  9. MySQL中INSERT的一般用法

    原文链接:http://www.blogjava.net/midnightPigMan/archive/2014/12/15/421406.html MySQL中INSERT的一般用法 INSERT语 ...

随机推荐

  1. windows批处理(cmd/bat)编程详解

    reference: http://blog.csdn.net/bingjie1217/article/details/12947327 http://www.cnblogs.com/doit8791 ...

  2. HDU 2121 Ice_cream’s world II 不定根最小树形图

    题目链接: 题目 Ice_cream's world II Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  3. hdu 2196

    树形dp 本文出自   http://blog.csdn.net/shuangde800 题目传送门 题意: 给出一棵树,求离每个节点最远的点的距离 思路: 把无根树转化成有根树分析, 对于上面那棵树 ...

  4. (二)、SSL证书

    从第一部分HTTPS原理中,我们可以了解到HTTPS核心的一个部分是数据传输之前的握手,握手过程中确定了数据加密的密码.在握手过程中,网站会向浏览器发送SSL证书,SSL证书和我们日常用的身份证类似, ...

  5. [unity3d]手游资源热更新策略探讨

    原地址:http://blog.csdn.net/dingxiaowei2013/article/details/20079683 我们学习了如何将资源进行打包.这次就可以用上场了,我们来探讨一下手游 ...

  6. XML注入介绍--XXE,XEE,xpath等

    XML注入指在请求的XML中插入攻击利用代码.根据不同的场景,可能会形成以下的漏洞形式: (1)XEE ----xml entity xpansion(xml实体膨胀,用于dos) 具体介绍:http ...

  7. Network Saboteur(Rand版)

    poj2531:http://poj.org/problem?id=2531 题意:给你一个图,图中点之间会有边权,现在问题是把图分成两部分,使得两部分之间边权之和最大.题解:随机算法 #includ ...

  8. 改写java TreeMap制造方便查询的ip内存库

    http://www.54chen.com/java-ee/chang-java-treemap-store-ip.html

  9. Android ActionBar 关于tab的应用 以及 TabListener的方法详解

    actionBar的tab标签应用以及TabListener的方法详解 package com.example.actionBarTest.actionBarTab; import android.a ...

  10. 欧拉工程第57题:Square root convergents

    题目链接 Java程序 package projecteuler51to60; import java.math.BigInteger; import java.util.Iterator; impo ...