mySql关于统计数量的SQL查询操作,状态,订单,语句,函数,数量

mySql关于统计数量的SQL查询操作

易采站长站,站长之家为您整理了mySql关于统计数量的SQL查询操作的相关内容。

我就废话不多说了,大家还是直接看代码吧~

select project_no,

sum(case when device_state=0 then 1 else 0 end)as offTotal ,

sum(case when device_state=1 then 1 else 0 end)as onlineTotal,

sum(1)total

from iot_d_device

group by project_no

order by project_no

补充:MySQL一条SQL语句查询多条统计结果

商城项目难免会遇到用户个人中心页查询不同状态订单数量的问题。当然这个问题并不难,可以写一个DAO层方法,以状态作为入参,每次传入不同状态值依次查询相应状态的订单数量。

今天在写H5端接口时,我想换种方式查,也就是通过一条SQL查询出多个状态的订单数量。在网上搜了搜,方法可行,所以就尝试了下,果不其然成功了。

示例如下(数据只为演示今天的问题,表设计并不严谨。勿怪):

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for mini_test_order

-- ----------------------------

DROP TABLE IF EXISTS `mini_test_order`;

CREATE TABLE `mini_test_order` (

`id` int(11) NOT NULL,

`order_no` varchar(32) DEFAULT NULL COMMENT '订单号',

`user_id` int(11) DEFAULT NULL COMMENT '用户id',

`shop_id` int(11) DEFAULT NULL COMMENT '商家id',

`order_status` tinyint(1) DEFAULT NULL COMMENT '订单状态',

`create_time` int(10) DEFAULT NULL COMMENT '创建时间',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of mini_test_order

-- ----------------------------

INSERT INTO `mini_test_order` VALUES ('1', 'aaaaaaaaa', '11', '111', '1', '1573041313');

INSERT INTO `mini_test_order` VALUES ('2', 'bbbbbbbb', '11', '222', '1', '1573041313');

INSERT INTO `mini_test_order` VALUES ('3', 'cccccccccc', '11', '333', '2', '1573041313');

INSERT INTO `mini_test_order` VALUES ('4', 'dddddddd', '11', '222', '3', '1573041313');

INSERT INTO `mini_test_order` VALUES ('5', 'eeeeeeeee', '11', '111', '4', '1573041313');

INSERT INTO `mini_test_order` VALUES ('6', 'ffffffffffffff', '11', '111', '3', '1573041313');

INSERT INTO `mini_test_order` VALUES ('7', 'gggggggg', '11', '222', '4', '1573041313');

INSERT INTO `mini_test_order` VALUES ('8', 'hhhhhhhhh', '11', '111', '4', '1573041313');

INSERT INTO `mini_test_order` VALUES ('9', 'iiiiiiiiiiiiiiiiiii', '11', '333', '3', '1573041313');

INSERT INTO `mini_test_order` VALUES ('10', 'jjjjjjjjjjjjjjjjjj', '11', '222', '1', '1573041313');

核心SQL语句如下:

SELECT COUNT(CASE order_status WHEN 1 THEN 1 END) AS "状态1",COUNT(CASE order_status WHEN 2 THEN 1 END) AS "状态2",COUNT(CASE order_status WHEN 3 THEN 1 END) AS "状态3",COUNT(CASE order_status WHEN 4 THEN 1 END) AS "状态4" FROM `mini_test_order`;

或如下:

SELECT COUNT(CASE WHEN order_status = 1 THEN 1 END) AS "状态1",COUNT(CASE WHEN order_status = 2 THEN 1 END) AS "状态2",COUNT(CASE WHEN order_status = 3 THEN 1 END) AS "状态3",COUNT(CASE WHEN order_status = 4 THEN 1 END) AS "状态4" FROM `mini_test_order` ;

当然,SQL语句不仅仅局限于上述两种写法,喜欢探究的童靴欢迎留言补充。

MySQL的case when的语法有两种

1.简单函数

CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END

2.搜索函数

CASE WHEN [expr] THEN [result1]…ELSE [default] END

两者区别

前者枚举col_name这个字段值为符合条件value1时所有可能的值;

后者可以写判断,并且搜索函数只会返回第一个符合条件的值,其他case被忽略。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持易采站长站。如有错误或未考虑完全的地方,望不吝赐教。以上就是关于对mySql关于统计数量的SQL查询操作的详细介绍。欢迎大家对mySql关于统计数量的SQL查询操作内容提出宝贵意见

mysql统计数量函数方法_mySql关于统计数量的SQL查询操作相关推荐

  1. mysql 如何调用函数结果_MySQL自定义函数调用不出结果

    自定义函数的代码: DROP FUNCTION IF EXISTS fn_HrStaffBase_GetNameFromidCard delimiter // CREATE FUNCTION fn_H ...

  2. mysql的字符串函数大全_MySQL的字符串函数大全

    ASCII(str) 返回字符串str的最左面字符的ASCII代码值.如果str是空字符串,返回0.如果str是NULL,返回NULL. mysql> select ASCII('2'); -& ...

  3. apmserv mysql_APMServ MySQL 1577错误解决方法_MySQL

    bitsCN.com APMServ MySQL 1577错误解决方法 Navicat导出任何一个数据库,都会提示:1577 – Cannot proceed because system table ...

  4. mysql中sum函数使用_MySQL中的SUM函数使用教程_MySQL

    MySQL的SUM函数是用来找出记录中各种的字段的总和. 要了解SUM函数考虑EMPLOYEE_TBL表具有以下记录: mysql> SELECT * FROM employee_tbl; +- ...

  5. mysql表格时间函数大全_mysql汇总数据函数

    -- 聚集函数(方便分析和报表生成,其实也就是进行简单的统计学的处理,不需要返回原表来浪费时间) /* 比如: 1.确定表中某些行数(或者满足某个条件或包含某个特定值的行数) 2.获得表中某些行的和 ...

  6. mysql新建data的方法_mysql建立数据库的方法

    mysql建立数据库的方法 方法一:使用create mysql> create database roudy; Query OK, 1 row affected (0.00 sec) mysq ...

  7. mysql还原数据的方法_MySQL 数据还原

    1.1还原使用mysqldump命令备份的数据库的语法如下: mysql -u root -p [dbname] < backup.sq 示例: mysql -u root -p < C: ...

  8. mysql查一个表3到5行的数据类型_MySQL入门(三) 数据库表的查询操作【重要】

    序言 本节比较重要,对数据表数据进行查询操作,其中可能大家不熟悉的就对于INNER JOIN(内连接).LEFT JOIN(左连接).RIGHT JOIN(右连接)等一些复杂查询. 通过本节的学习,可 ...

  9. mysql语句在哪编写_mysql常见问题七:编写sql语句

    一.删除除了学号字段以外,其它字段都相同的冗余记录,只保留一条!(也就是要删除凤姐和田七中一条重复数据只留一条) 要求结果数据: 原始数据: CREATE TABLEtbl_students ( id ...

最新文章

  1. 高效的沟通方式-会议
  2. Halcon知识:如何求一个工件的粗细
  3. vue 实现动态增加输入框_vue实现一个6个输入框的验证码输入组件
  4. np.reshape带给我的内存错误
  5. 详细描述一下 Elasticsearch 更新和删除文档的过程。
  6. Java如何将Ftp文件解压_ftp解压工具,ftp解压工具在java环境下配置其连接
  7. 最小化安装CentOS 7后,图形界面的安装(GNOME、KDE等)
  8. iframe:获取iframe中的元素
  9. SPSS调节效应检验(图文+数据集)【SPSS 045期】
  10. 软件行业的职位英文简称
  11. 谷歌地球看不了街景_PPT放入3D模型之后,居然能模拟谷歌地图!
  12. IPV6 阿里DDNS
  13. 黑灰对比可以为高大上网站风格代言
  14. PAT乙级-1051复数乘法(保留两位数-四舍五入)
  15. 微信小程序是否支持手机定位经纬度坐标
  16. 如何查阅NLP资料 转自https://blog.csdn.net/qq_27009517/article/details/80841146
  17. Basler相机环境配置
  18. python爬虫-爬取当当网书籍信息存到Excel中
  19. CreateJS-EaseJS 应用
  20. 系统集成项目管理工程师资料分享

热门文章

  1. iPhone回收中这样看划痕就不会被压价了
  2. PyQt5_股票技术图形查看工具
  3. RK3128适配RTL8723DU
  4. 批量导出QQ好友清单的方法
  5. 11、struct 结构
  6. 什么是IC卡、M1卡,有啥区别
  7. 上海计算机一级二级三级考纲,上海高校计算机一级考纲.doc
  8. [英文歌曲]斗士:Fighter
  9. 儿童高脚椅、餐椅安全标准ASTM F404
  10. vue2 + vuex 高度还原 饿了么 App,用真实数据登陆官网,并实现购物车、下单功能