当前位置: 首页 > news >正文

工信部备案网站打不开/seo排名赚app官网

工信部备案网站打不开,seo排名赚app官网,云seo关键词排名优化软件,网站院长信箱怎么做前言 在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结CASE WHEN、IF、IFNULL三种函数。 1 CASE WHEN Case when语句能在SQL语句中织入判…

前言

在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结CASE WHENIFIFNULL三种函数。

1 CASE WHEN

Case when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。

CASE WHEN语句分为简单函数和条件表达式。

1、简单函数

CASE 字段 WHEN 预期值 THEN 结果1 ELSE 结果2 END

如果字段值等于预期值,则返回结果1,否则返回结果2。

下面通过一个简单的示例来看一下具体用法。

表score:
在这里插入图片描述
场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。

SQL语句

SELECT name,(CASE sex WHEN 0 THEN '女' ELSE '男' END) sex FROM score

结果
在这里插入图片描述
2、条件表达式

CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:

CASE WHEN condition THEN result1  ELSE result2
END

解释一下,语句中的condition是条件判断,如果该判断结果为true,那么CASE语句将返回result,否则返回result2,如果没有ELSE,则返回null。CASE与END之间可以有多个WHEN…THEN…ELSE语句。END表示CASE语句结束。

场景:score 大于等于90为优秀,80-90为良好,60-80为及格,小于60为不及格,用SQL语句统计出每个学生的成绩级别。

SQL:

SELECT name,score,(CASE WHEN score>=90 THEN '优秀' WHEN score>=80 THEN '良好' WHEN score>=60 THEN '及格' ELSE '不及格' END) level 
FROM score

结果
在这里插入图片描述
3、综合使用

CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。

先看第1个场景

在下表score(sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。
在这里插入图片描述
SQL:

SELECT SUM(CASE WHEN sex=0 THEN 1 ELSE 0 END) AS 女生人数,SUM(CASE WHEN sex=1 THEN 1 ELSE 0 END) AS 男生人数,SUM(CASE WHEN score>=60 AND sex=0 THEN 1 ELSE 0 END) 男生及格人数,SUM(CASE WHEN score>=60 AND sex=1 THEN 1 ELSE 0 END) 女生及格人数
FROM score;

结果
在这里插入图片描述
再看第2个场景
在这里插入图片描述
将上面的score表转换为下面形式:
在这里插入图片描述
SQL:

SELECT name,MAX(CASE course WHEN '语文' THEN score ELSE 0 END) AS '语文',max(CASE course WHEN '数学' THEN score ELSE 0 END) AS '数学',max(CASE course WHEN '英语' THEN score ELSE 0 END) AS '英语',AVG(score) AS '平均成绩'
FROM score GROUP BY name;

结果如下:
在这里插入图片描述

2 IF

IF函数也能通过判断条件来返回特定值,它的语法如下:

IF(expr,result_true,result_false)

expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。

用一个示例演示,还是表score:
在这里插入图片描述
使用IF函数:

SELECT name,IF(sex=1,'男','女')sex FROM students;

可以看出,在一些场景中,IF函数和CASE WHEN是有同样效果的,前者相对简单,后者能应对更复杂的判断。

另外,IF函数还可以和聚合函数结合,例如查询班级男生女生分别有多少人:

SELECT COUNT(IF(sex=1,1,NULL)) 男生人数,COUNT(IF(sex=0,1,NULL))女生人数 FROM students

在这里插入图片描述

3 IFNULL

在Java程序中调用sql语句时,如果返回结果是null,是非常容易引发一些意外情况的。
在这里插入图片描述
因此,我们希望在SQL中做一些处理,如果查询结果是null,就转换为特定的值,这就要用到Mysql中IFNULL函数。

首先SQL一般写法是这样的:

SELECT  price FROM goods WHERE name='light';

使用IFNULL改写一下:

SELECT IFNULL(price,0) price FROM goods WHERE name='light';

但使用IFNULL语句,如果where条件中的name值是不存在的,那么仍将返回null,例如:

-- 返回结果:null
SELECT IFNULL(price,0) price FROM goods WHERE name='aaa';

这时候,需要改写成下面的形式:

-- 返回结果:0
SELECT IFNULL((SELECT price FROM goods WHERE name='aaa'),0) price;

在实际应用中,如果你确定where条件的值一定存在,使用前者就可以了,否则要用后者。

IFNULL函数也可以结合聚合使用,例如:

-- 返回结果:0
SELECT IFNULL(SUM(price),0) FROM goods WHERE status=3;

其他,AVGCOUNT等用同样方式处理,而且,无论where条件存在不存在,结果都是会返回0的。

http://www.lbrq.cn/news/1608157.html

相关文章:

  • 常州哪些网站公司做的好处/网站推广建站
  • 做阿里网站卖东西赚钱吗/百度云登录
  • html网站建设方案/seo是怎么优化的
  • php语言 电商网站建设/品牌策划设计
  • 杭州网站建设招聘网/深圳营销型网站设计公司
  • 做网站后端的是什么部门/点击进入官方网站
  • 怎么做好网站营销/免费seo网站的工具
  • 网站建设及发布的流程/拼多多推广引流软件免费
  • wordpress接入微信登录/河南seo关键词排名优化
  • 用python做网站开发的课程/seo数据统计分析工具有哪些
  • 南平建设集团有限公司网站/网站运营与维护
  • 青岛专业做网站的公司有哪些/怎么在网上做广告
  • 网站怎么设置二级域名/手机建立一个免费网站
  • 网站建设设备/南宁网站推广排名
  • 学生兼职网站开发/济南疫情最新消息
  • 货源网站开发/网络营销师培训
  • 做桑拿网站犯法吗/长沙正规seo优化公司
  • 如何做网站的主页/视频网站搭建
  • 做独立网站的好处/廊坊百度快照优化哪家服务好
  • 北京病毒变异最新消息/青岛seo博客
  • 网站举报中心官网/百度一对一解答
  • destoon 网站搬家/湖南网络推广排名
  • 公务员可以自己做网站吗/如何做营销策划方案
  • 如何做一张网站平面效果图/磁力兔子搜索引擎
  • 免费网站论坛/百度搜索引擎收录
  • 永康网站开发/网络营销和传统营销有什么区别
  • 宝应网站/宁波网站关键词排名推广
  • 简洁网站倒计时代码/精准客源app
  • 附近注册公司代理机构/成都网站seo
  • 注册一家公司最低需要多少钱/seo查询排名系统
  • JVM学习日记(十五)Day15——性能监控与调优(二)
  • 编译旧版本的electron内核
  • 【计算机网络】Socket网络编程
  • 机器学习【五】decision_making tree
  • QT中使用OpenCV保姆级教程
  • AR智能巡检系统:制造业设备管理的效率革新