case when用法 Sqlserver的case when 用法(SQL语句中case,when,then的用法)
---下文举例分析了case?when常用的用法,如下所示:涉及排序字段的应用 create?table?test( qty?int?, sort?v...
很高兴有机会和大家一起谈论case when用法的话题。这个问题集合包含了一些常见和深入的问题,我将详细回答每一个问题,并分享我的见解和观点。

Sqlserver的case when 用法
---下文举例分析了case?when常用的用法,如下所示:涉及排序字段的应用 create?table?test(
qty?int?, sort?varchar(20))
insert?into?test(qty,sort)values
(1,'a'),(2,'b'),(3,'d'),(1,'e')
go
----方法1:
select?sort,qty,
case?qty
when?1?then?'少'
when?2?then?'中'
when?3?then?'多'
else?'未知'
end?as?[数量范围]
from?test?
--方法2:
select?sort,qty,
case?
when?qty=1?then?'少'
when?qty=2?then?'中'
when?qty=3?then?'多'
else?'未知'
end?as?[数量范围]
from?test?
---sum统计用法
select?
sum(?casewhen?qty=1?then?1?else?0?end)?as?[少], sum(?case?qtywhen2?then?1?else?0?end)?as?[中], sum(?casewhen?qty=3?then?1?else?0?end)?as?[多], sum(?casewhen?qty<>?1?and?qty?<>2?and?qty?<>3?then?1?else?0?end)?as?[位置]from?test?
---case?when?做排序字段 declare?@i?int? set?@i=0 select?*?from?test? order?by? case?@i?when?0?then?qty?else?sortend?go
truncate?table?test
drop?table?test
PLSQL中,select case..when.. then..什么意思?怎么用?
case when ... then .. when .. then ... end
这种表达式,是sql的不同条件分支结果。
举例如下,
1、创建数据表,create table test_student(stu_id number, class_id number);
2、插入测试数据,
insert into test_student values(1,1001);
insert into test_student values(2,1001);
insert into test_student values(3,1002);
insert into test_student values(4,1003);
insert into test_student values(5,1003);
insert into test_student values(6,1003);
3、查询表中数据,select * from?test_student ,
4、编写case when 表达式,将class_id翻译为中文名称,sql如下,
select t.*,
case
?when class_id = 1001 then
? '语文'
?when class_id = 1002 then
? '数学'
?when class_id = 1003 then
? '英语'
end as class_name
from test_student t;条件判断函数-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
SQL语句中case,when,then的用法
用法如下:
复制代码
SELECT
s.s_id,
s.s_name,
s.s_sex,
CASE
WHENs.s_sex='1'THEN'男'
WHENs.s_sex='2'THEN'女'
ELSE'其他'
ENDassex,
s.s_age,
s.class_id
FROM
t_b_students
WHERE
1=1
这两个结果是一样的:
需要注意的一点是,Case函数只返回第一个限定值,其余的Case将被自动忽略。
扩展资料:
Case有两种格式:简单函数和Case搜索函数。
简单的例子功能:
CASEsex
WHEN‘1’THEN‘男’
WHEN‘0’THEN‘女’
ELSE‘其他’END
Case搜索函数:
CASEWHENsex=‘1’THEN‘男’
WHENsex=‘0’THEN‘女’
ELSE‘其他’END
显然简单的Case函数天生简洁,但它们只适用于这种单字段单值比较,而Case搜索函数具有适用于所有比较用例的优势。
另一个需要注意的问题是,在Case函数满足了某个条件之后,其余的条件将被自动忽略,这样即使满足了多个条件,在执行过程中也只能识别第一个条件。
当使用CASEWHEN时,您可以将其视为没有字段名的字段,字段值是有条件的,并且在需要使用字段名时可以使用as来定义别名。
关于sql server中 case when then中 or 的用法?
case when中的各个条件不能有交集,否则会出现异常
该例的结果应该如下:
select id,[name],
score=case when uscore>=80 or cscore>=90 then '优'
when uscore<60 or cscore<70 then '不及格'
else '中等' end
from userinfo
再看一下case when语法如下: 各个条件表达式要互不相交
case when 条件表达式1 then 结果表达式1
when 条件表达式2 then 结果表达式2
。。。。 else 结果表达式n
end
如果要用到or或者and操作,肯定是在条件表达式中有多个判断逻辑需要操作
比如 case when a>10 or a<5 then '结果1' else '结果2' end
这样就会区分大于10或者小于5的记录
oracle case when用法是怎么样的?
oracle case when用法是:
1、导入用户(从用户scott导入到用户scott)。
impdp scott/tiger@orcl directory=dump_dir dumpfile=expdp。dmp schemas=scott。
2、导入表(从scott用户中把表dept和emp导入到system用户中)。
impdp system/manager@orcl directory=dump_dir。
dumpfile=expdp。dmptables=scott。dept,scott。emp remap_schema=scott:system。
系统简介
ORACLE数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一。
比如SilverStream就是基于数据库的一种中间件。ORACLE数据库是世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。

今天关于“case when用法”的讲解就到这里了。希望大家能够更深入地了解这个主题,并从我的回答中找到需要的信息。如果您有任何问题或需要进一步的信息,请随时告诉我。
