db2case语句_SQL中的IF ELSE(CASE语句的使用)

SQL中的IF ELSE(CASE语句的使用)

标签(空格分隔): SQL DB2

大家对IF ELSE语句可能都很熟悉,它是用来对过程进行控制的。在SQL的世界中CASE语句语句有类似的效果。下面简单的介绍CASE语句的用法。考虑下面的情况,假设有个user表,定义如下:

CREATE TABLE

USER

(

NAME VARCHAR(20) NOT NULL,---姓名

SEX INTEGER,---性别(1、男 2、女)

BIRTHDAY DATE---生日

);

CASE使用场合1:把user表导出生成一个文件,要求性别为男或女,而不是1和2,怎么办?我们可以用如下的语句处理:

SELECT

NAME,

CASE SEX

WHEN 1 HEN '男' ELSE '女'

END AS SEX,

BIRTHDAY

FROM

USER;

CASE使用场合2:假设user目前没有值,然后你往user导入了一批数据,但是很不幸,错把男设置成为2,而把女设置成为1,现在要求你变换过来,怎么办?

方法1:使用三条语句,先把2更新成3,接着把1更新成2,最后把3更新成1,很麻烦,不是吗?

UPDATE USER SET SEX=3 WHERE SEX=2;

UPDATE USER SET SEX=1 WHERE SEX=3;

UPDATE USER SET SEX=2 WHERE SEX=1;

方法2:使用CASE语句

UPDATE USER SET SEX=

(

CASE SEX

WHEN 1 THEN 2

WHEN 2 THEN 1

ELSE SEX

END

);

细心的朋友可能已经发现了,上面的方法1的三条语句的执行顺序有问题,没错,是我故意那些写的,仅仅是把1变成2,把2变成1就那么麻烦,而且很容易出错,想象一下,如果有很多这样的值需要变换,那是一种什么样的情况。还好,我们有CASE语句,有好多这样的值需要变换,CASE语句也不会存在问题。可能有些朋友还是有疑虑,这样做会不会死循环啊?哈哈,想法很好,如果你发现这样做会死循环,一定要告诉IBM,我反正没发现。

CASE使用场合3:假设让你把张三的生日更新成1949-10-1,李四的生日更新成1997-7-1等,类似这样的更新由很多。该怎么办呢?非常简单,大多数人会这么做。

update USER set BIRTHDAY='1949-10-1' where NAME='张三';

update USER set BIRTHDAY='1997-7-1' where NAME='李四';

当USER表的数据量非常大,而NAME字段上又没有索引时,每条语句都要进行全表扫描,如果这样的语句有很多,效率会非常差,这时候我们可以用CASE语句,如下:

UPDATE USER SET BIRTHDAY=

(

CASE NAME

WHEN '张三' THEN '1949-10-1'

WHEN '李四' THEN '1997-7-1'

ELSE BIRTHDAY

END

)

where NAME in ('张三','李四');

以上语句只进行一次全表扫描,效率非常高。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DB2,可以使用CASE WHEN、ELSEIFELSE语句来创建条件表达式。这些语句通常与SELECT、UPDATE和DELETE等查询和更新语句一起使用CASE WHEN语句用于根据条件表达式的返回结果进行不同的操作。它根据CASE WHEN后面的条件表达式的结果,选择一个特定的执行路径,并返回相应的结果。语法如下: ```sql CASE <expression> WHEN <value1> THEN <result1> WHEN <value2> THEN <result2> ... ELSE <result> END ``` 其,<expression>是用于评估的条件表达式,<value1>、<value2>等是可能的值,<result1>、<result2>等是对应于每个条件的返回结果。如果条件表达式的结果与某个WHEN子句匹配,则执行相应的操作并返回该结果。如果没有匹配的条件,则执行ELSE子句的操作并返回该结果。 ELSEIF语句用于在多个条件之间进行逐个判断,根据满足的条件执行相应的操作。语法如下: ```sql CASE WHEN <condition1> THEN <result1> ELSEIF <condition2> THEN <result2> ... ELSE <result> END ``` 在这个语法,如果没有满足第一个条件的情况,那么会检查第二个条件,如果满足,则执行相应的操作并返回结果。如果所有条件都不满足,则执行ELSE子句的操作并返回该结果。 ELSE语句用于在没有满足任何条件时的默认操作。如果CASE WHEN或ELSEIF语句没有匹配的条件,那么就会执行ELSE子句的操作并返回该结果。语法如下: ```sql CASE WHEN <condition1> THEN <result1> WHEN <condition2> THEN <result2> ... ELSE <result> END_LAMBDA ``` 请注意,以上是使用DB2CASE WHEN、ELSEIFELSE的基本语法。实际使用时,可能需要根据你的具体需求进行调整和扩展。此外,CASE语句还可以与其他SQL函数和表达式结合使用,以实现更复杂的条件逻辑和数据转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值