题意:

将用户划分为25岁以下和25岁及以上两个年龄段,分别查看这两个年龄段用户数量


分解:


  • 由划分为25岁以下和25岁及以上,知:age<25 or age is null ,age>=25
  • 由查看用户数量,知:count(*)
  • 由age为null,知:age is null
    此题共有3种解题方案,如下

代码:


  • 法一 联合查询:
SELECT '25岁以下' age_cut,COUNT(device_id) Number    #查询结果前面新增一列age_cut,这一列可以不在原表中
FROM user_profile
WHERE age < 25 OR age IS NULL
UNION
SELECT '25岁及以上' age_cut,COUNT(device_id) Number
FROM user_profile
WHERE age >= 25

  • 法二 搜索case函数:
select
case 
when age < 25 OR age IS NULL then '25岁以下'
when age>=25 then '25岁及以上'
end age_cut,count(*) number
from user_profile
group by age_cut  

  • 法三 if判断:
select 
if(age>=25,'25岁及以上','25岁以下') age_cut,count(*) number
from user_profile
group by age_cut

补充知识点1--case 函数


case函数分为:简单case函数,搜索case函数

  • 简单case函数
    计算测试表达式,按从上到下的书写顺序将测试表达式的值与每个WHEN子句的简单表达式进行比较。
  select 列1,列2
  case 列3
  when 值1 then 结果1
  when 值2 then 结果2
  when 值n then 结果n
  [else 结果n+1]
  end 别名,列名4,列名5
  from 表名  
  • 搜索case函数
    按从上到下的书写顺序计算每个WHEN子句的布尔表达式。 返回第一个取值为TRUE的布尔表达式所对应的结果表达式的值。
select 
case 
when 列及判断条件1 then 结果1 
when 列及判断条件 then 结果2
when 列及判断条件 then 结果n
[else 结果n+1]
end 别名,列名2,列名3
from 表名  
  • 综合应用
    统计职工表中各个部门男性数量及女性数量分别为多少
select department,
count(case when sex='男' then '男' end)'男员工数量',
count(case when sex='女' then '女' end)'女员工数量',
from Employe
group by department

补充知识点2 if表达式


  • if表达式
    if (exper1,exper2,exper3)
    如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。 作为表达式的if也可以用CASE when来实现:
select *,if(sex='男',"男","女") as '员工性别' from department where sex != ""

select *,if(sex='男',"男","女") as '员工性别' from department where sex != ""
  • ifnull
    IFNULL(expr1,expr2)
    假如expr1 不为 NULL,则 IFNULL() 的返回值为 expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。