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

苏州做企业网站的公司重庆今天刚刚发生的新闻

苏州做企业网站的公司,重庆今天刚刚发生的新闻,wordpress 背景颜色,wordpress 页面代码事情初始是,在开发中有一个需求,根据某个字段匹配某个值时统计该值出现的总数,这段话可能有点绕,简单举个例子, 有如下数据表, 在score表中,sex为1表示男性,sex0表示女性,查询时转换成汉字显示 这时候就可以用mysql中的case函数来实现 Case …

        事情初始是,在开发中有一个需求,根据某个字段匹配某个值时统计该值出现的总数,这段话可能有点绕,简单举个例子,

        有如下数据表,

在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示

这时候就可以用mysql中的case函数来实现

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

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

简单函数

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

SQL语句

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

结果

条件表达式

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

结果

综合使用

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

在下表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;

结果

 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的。

OK,接下来自己上手操作

SELECT
IFNULL(SUM(CASE tbmachine.machine_typeWHEN 'DEV-HL' THEN1ELSE0END 
) ,0) as 'machineNum'
FROMtoymachine.tbmachine;

结果如下 

 

与聚合函数查询结果比对

SELECTcount(m.uk_key_id)
FROMtoymachine.tbmachine m
WHEREm.machine_type='DEV-HL';

这里直接统计主键数量, 

 

继续验证结果正确性

分别统计每种类型的数量

SELECTm.machine_type,COUNT(m.machine_type)
FROMtoymachine.tbmachine m
GROUP BYm.machine_type;

 

OK,结果一致,大功告成 

 

http://www.yayakq.cn/news/384862/

相关文章:

  • 深圳优化网站排名网站一键收录
  • 泰州专业做网站公司校友会网站建设的目的
  • 计算机应用技术php网站开发江苏省交通运输厅门户网站建设管理办法
  • 网站设计 线框图 怎么画厦门人才网最新招聘信息网
  • 个人做网站哪种类型的网站好wordpress 极简 文字
  • 7个优秀网站设计赏析上海室内软装设计公司排名
  • 网站怎么优化关键词望野眼上海话
  • 葫芦岛网站公司content timeline wordpress
  • 外贸平台都有什么网站wordpress 移动客户端
  • icann 域名注册网站新媒体运营面试问题
  • 建设的比较好的档案馆网站如何做品牌推广方案
  • 成都门户网站建设公司花店电子商务网站建设课题设计
  • 国外 网站设计阿里巴巴司法拍卖网官网
  • 网站设计与开发技术教程去哪里找做网站的人
  • 手机投资理财网站建设深圳设计网站公司
  • 品牌官方网站网站的建设期
  • 做宽带销售网站干果坚果网站建设
  • 北京企业网站seo岷县网站建设
  • 做的比较漂亮的中国网站php网站开发工程师认证证书
  • 帮企业建网站步骤域名服务器如何申请
  • 网站建设优化推广安徽临沂网站制作公司6
  • 兼职做问卷调查的网站怎么制作一个团购小程序
  • 做电子章网站云南建设投资控股集团有限公司网站
  • 上海网站备案要求吗themes for wordpress
  • 好的网站设计培训学校网站 信息内容建设 存在问题
  • 典型营销型网站有哪些公司网站在哪备案
  • 个人可以备案网站青岛建设投资公司网站
  • 建筑网站开发wordpress安装后403
  • 大淘客做的网站打不开网易企业邮箱格式
  • 网站建设公司工资设置编辑wordpress代码