前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MYSQL中case when语法的作用

MYSQL中case when语法的作用

原创
作者头像
C4rpeDime
发布2018-07-23 23:11:18
2.9K0
发布2018-07-23 23:11:18
举报
文章被收录于专栏:黑白安全黑白安全
MYSQL中case when语法的作用 MYSQL中case when语法的作用 系统安全
MYSQL中case when语法的作用 MYSQL中case when语法的作用 系统安全

严格来讲,不应该叫“mysql条件判断语句case when语法”的,它的专业语术是:“mysql流程控制语句case语法”;这一点对于做程序的人来说一定要清楚。

CASE语法:

SQL

代码语言:javascript
复制
CASE case_value
WHEN when_value THEN statement_list
[WHEN when_value THEN statement_list] ...
[ELSE statement_list]
END CASE
或
CASE
WHEN search_condition THEN statement_list
[WHEN search_condition THEN statement_list] ...
[ELSE statement_list]
END CASE

CASE存储程序 的语句实现了一个复杂的条件结构。

注意:也有一个表达,这不同于这里描述的 陈述。该 声明不能有一个 条款,而是终止 而不是。 CASE CASE CASEELSE NULLEND CASEEND

CASE语法说明:

对于第一个语法,case_value是一个表达式。将该值与when_value每个WHEN子句中的表达式进行 比较, 直到其中一个相等。当when_value找到平等时,相应的THEN子句 statement_list执行。如果不 when_value相等,则该 ELSE子句 statement_list执行,如果有的话。

这个语法不能用于测试是否相等, NULL因为NULL = NULL 是错误的。

对于第二种语法,将对每个WHEN子句 search_condition表达式进行求值,直到其中一个为真,此时它的对应 THEN子句将 statement_list执行。如果不 search_condition相等,则该 ELSE子句 statement_list执行,如果有的话。

如果否when_value或 search_condition匹配测试的值,并且CASE语句不包含任何ELSE子句,则CASE语句错误结果将找不到Case。

每个statement_list由一个或多个SQL语句组成; 一个空的 statement_list是不允许的。

CASE代码示例:

1、要处理没有任何值与任何WHEN子句匹配的情况 ,请使用ELSE 包含空白 BEGIN ... END块的情况,如下所示。

代码语言:javascript
复制
DELIMITER |
CREATE PROCEDURE p()
BEGIN
DECLARE v INT DEFAULT 1;
CASE v
WHEN 2 THEN SELECT v;
WHEN 3 THEN SELECT 0;
ELSE
BEGIN
END;
END CASE;
END;
|

2、sql语句查询时给某个空字段赋值

代码语言:javascript
复制
SELECT
CASE
WHEN field= '' THEN
'1'
WHEN field IS NULL THEN
'1'
ELSE
field
END
FROM
tablename

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档