SELECT IF(sva=1,"男","女") AS s FROM table_name WHERE sva != ‘‘;
三、IFNULL(expr1,expr2)
仅适用于mysql
假如expr1 不为 NULL,则 IFNULL() 的返回值为 expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。
SELECT IFNULL(1,0); -> 1SELECT IFNULL(NULL,10); -> 10SELECT IFNULL(1/0,10);-> 10SELECT IFNULL(1/0,‘yes‘);-> ‘yes‘
四、ISNULL
仅适用于 sqlserver
SELECT ISNULL(null,10) -> 10SELECT ISNULL(1,10);-> 1SELECT ISNULL(1/1,‘yes‘);-> 1SELECT ISNULL(‘abc‘,11)->abcSELECT ISNULL(null,‘abc‘)->abcSELECT ISNULL(null,2.130)->2.130SELECT ISNULL(null,‘哈哈‘)->哈哈SELECT ISNULL(‘‘,‘哈哈‘)->‘‘
五、IF ELSE
仅适用于 sqlserver
IF 1>0 SELECT 1 ELSE IF 1<0 SELECT 2 ELSE SELECT 3
相关文档: https://www.yiibai.com/sqlserver/sql-server-if-else.html
下面的用法是错误的:
select (IF a.[胸径] != ‘‘Begin Cast([胸径] as float)EndElseBegin End)from [dbo].[植物标本数据1] as a
正确的方法是使用 case when then
select
(case when [胸径] != ‘‘ and [胸径] is not null then Cast([胸径] as float) else null end) as xjfrom [植物标本数据1]
参考资料:
https://www.cnblogs.com/studynode/p/9881900.html
SQL中的条件判断语句(case when zhen if,ifnull)用法
标签:实现 title 技术 sum pos 判断 http toolbar 使用
小编还为您整理了以下内容,可能对您也有帮助:
条件判断函数-CASE WHEN、IF、IFNULL详解
在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结 CASE WHEN 、 IF 、 IFNULL 三种函数。
Case when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。
CASE WHEN语句分为简单函数和条件表达式。
1、简单函数
如果字段值等于预期值,则返回结果1,否则返回结果2。
下面通过一个简单的示例来看一下具体用法。
表score:
场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。
SQL语句:
结果:
2、条件表达式
CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:
解释一下,语句中的condition是条件判断,如果该判断结果为true,那么CASE语句将返回result,否则返回result2,如果没有ELSE,则返回null。CASE与END之间可以有多个WHEN…THEN…ELSE语句。END表示CASE语句结束。
场景:score 大于等于90为优秀,80-90为良好,60-80为及格,小于60为不及格,用SQL语句统计出每个学生的成绩级别。
SQL:
结果:
3、综合使用
CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。
先看第1个场景
在下表 score (sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。
SQL:
结果:
再看第2个场景
将上面的score表转换为下面形式:
SQL:
结果如下:
IF函数也能通过判断条件来返回特定值,它的语法如下:
expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。
用一个示例演示,还是表score:
使用IF函数:
可以看出,在一些场景中, IF 函数和 CASE WHEN 是有同样效果的,前者相对简单,后者能应对更复杂的判断。
另外,IF函数还可以和聚合函数结合,例如查询班级男生女生分别有多少人:
在Java程序中调用sql语句时,如果返回结果是 null ,是非常容易引发一些意外情况的。
因此,我们希望在SQL中做一些处理,如果查询结果是 null ,就转换为特定的值,这就要用到Mysql中 IFNULL 函数。
首先SQL一般写法是这样的:
使用 IFNULL 改写一下:
但使用 IFNULL 语句,如果 where 条件中的 name 值是不存在的,那么仍将返回 null ,例如:
这时候,需要改写成下面的形式:
在实际应用中,如果你确定 where 条件的值一定存在,使用前者就可以了,否则要用后者。
IFNULL 函数也可以结合聚合使用,例如:
其他, AVG 、 COUNT 等用同样方式处理,而且,无论 where 条件存在不存在,结果都是会返回0的。
END
引用链接:blog.csdn.net/mu_wind/article/details/93976316
条件判断函数-CASE WHEN、IF、IFNULL详解
在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结 CASE WHEN 、 IF 、 IFNULL 三种函数。
Case when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。
CASE WHEN语句分为简单函数和条件表达式。
1、简单函数
如果字段值等于预期值,则返回结果1,否则返回结果2。
下面通过一个简单的示例来看一下具体用法。
表score:
场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。
SQL语句:
结果:
2、条件表达式
CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:
解释一下,语句中的condition是条件判断,如果该判断结果为true,那么CASE语句将返回result,否则返回result2,如果没有ELSE,则返回null。CASE与END之间可以有多个WHEN…THEN…ELSE语句。END表示CASE语句结束。
场景:score 大于等于90为优秀,80-90为良好,60-80为及格,小于60为不及格,用SQL语句统计出每个学生的成绩级别。
SQL:
结果:
3、综合使用
CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。
先看第1个场景
在下表 score (sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。
SQL:
结果:
再看第2个场景
将上面的score表转换为下面形式:
SQL:
结果如下:
IF函数也能通过判断条件来返回特定值,它的语法如下:
expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。
用一个示例演示,还是表score:
使用IF函数:
可以看出,在一些场景中, IF 函数和 CASE WHEN 是有同样效果的,前者相对简单,后者能应对更复杂的判断。
另外,IF函数还可以和聚合函数结合,例如查询班级男生女生分别有多少人:
在Java程序中调用sql语句时,如果返回结果是 null ,是非常容易引发一些意外情况的。
因此,我们希望在SQL中做一些处理,如果查询结果是 null ,就转换为特定的值,这就要用到Mysql中 IFNULL 函数。
首先SQL一般写法是这样的:
使用 IFNULL 改写一下:
但使用 IFNULL 语句,如果 where 条件中的 name 值是不存在的,那么仍将返回 null ,例如:
这时候,需要改写成下面的形式:
在实际应用中,如果你确定 where 条件的值一定存在,使用前者就可以了,否则要用后者。
IFNULL 函数也可以结合聚合使用,例如:
其他, AVG 、 COUNT 等用同样方式处理,而且,无论 where 条件存在不存在,结果都是会返回0的。
END
引用链接:blog.csdn.net/mu_wind/article/details/93976316
case when用法sql
在SQL中,“Case When”语句用法如下:
在SQL中,“Case When”语句用于选择判断,在执行时先对条件进行判断,然后根据判断结果做出相应的操作;语法“CASE 字段 WHEN 条件1 THEN 操作1 WHEN 条件2 THEN 操作2...ELSE 操作n END;”。
SQL 是一种操作数据库的语言,包括创建数据库、删除数据库、查询记录、修改记录、添加字段等。SQL 虽然是一种被 ANSI 标准化的语言,但是它有很多不同的实现版本。
SQL 是 Structured Query Language 的缩写,中文译为“结构化查询语言”。SQL 是一种计算机语言,用来存储、检索和修改关系型数据库中存储的数据。
SQL 是关系型数据库的标准语言,所有的关系型数据库管理系统(RDBMS),比如 MySQL、Oracle、SQL Server、MS Access、Sybase、Informix、Postgres 等,都将 SQL 作为其标准处理语言。
此外,SQL 也有一些变种,就像中文有很多方言,比如:
微软的 SQL Server 使用 T-SQL;
Oracle 使用 PL/SQL;
微软 Access 版本的 SQL 被称为 JET SQL(本地格式)。
case when用法sql
SQL中Case When的用法如下:
case when类似于编程语言中的if else判断、switch case语句。该语句执行时先对条件进行判断,然后根据判断结果做出相应的操作。
Case具有两种格式:简单Case函数和Case搜索函数。简单Case函数胜在简洁,但是它只适用于这种单字段的单值比较,而Case搜索函数的优点在于适用于所有比较的情况。
注意事项
Case函数在满足了某个符合条件后,剩下的条件将会被自动忽略,因此,即使满足多个条件,执行过程中也只认第一个条件。
在使用 CASE WHEN时,可以把它当作一个逻辑上的匿名字段,字段值根据条件确认,在需要使用字段名时可以是用 as来定义别名。