mysql统计数量函数方法_mySql关于统计数量的SQL查询操作
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查询操作相关推荐
- mysql 如何调用函数结果_MySQL自定义函数调用不出结果
自定义函数的代码: DROP FUNCTION IF EXISTS fn_HrStaffBase_GetNameFromidCard delimiter // CREATE FUNCTION fn_H ...
- mysql的字符串函数大全_MySQL的字符串函数大全
ASCII(str) 返回字符串str的最左面字符的ASCII代码值.如果str是空字符串,返回0.如果str是NULL,返回NULL. mysql> select ASCII('2'); -& ...
- apmserv mysql_APMServ MySQL 1577错误解决方法_MySQL
bitsCN.com APMServ MySQL 1577错误解决方法 Navicat导出任何一个数据库,都会提示:1577 – Cannot proceed because system table ...
- mysql中sum函数使用_MySQL中的SUM函数使用教程_MySQL
MySQL的SUM函数是用来找出记录中各种的字段的总和. 要了解SUM函数考虑EMPLOYEE_TBL表具有以下记录: mysql> SELECT * FROM employee_tbl; +- ...
- mysql表格时间函数大全_mysql汇总数据函数
-- 聚集函数(方便分析和报表生成,其实也就是进行简单的统计学的处理,不需要返回原表来浪费时间) /* 比如: 1.确定表中某些行数(或者满足某个条件或包含某个特定值的行数) 2.获得表中某些行的和 ...
- mysql新建data的方法_mysql建立数据库的方法
mysql建立数据库的方法 方法一:使用create mysql> create database roudy; Query OK, 1 row affected (0.00 sec) mysq ...
- mysql还原数据的方法_MySQL 数据还原
1.1还原使用mysqldump命令备份的数据库的语法如下: mysql -u root -p [dbname] < backup.sq 示例: mysql -u root -p < C: ...
- mysql查一个表3到5行的数据类型_MySQL入门(三) 数据库表的查询操作【重要】
序言 本节比较重要,对数据表数据进行查询操作,其中可能大家不熟悉的就对于INNER JOIN(内连接).LEFT JOIN(左连接).RIGHT JOIN(右连接)等一些复杂查询. 通过本节的学习,可 ...
- mysql语句在哪编写_mysql常见问题七:编写sql语句
一.删除除了学号字段以外,其它字段都相同的冗余记录,只保留一条!(也就是要删除凤姐和田七中一条重复数据只留一条) 要求结果数据: 原始数据: CREATE TABLEtbl_students ( id ...
最新文章
- 高效的沟通方式-会议
- Halcon知识:如何求一个工件的粗细
- vue 实现动态增加输入框_vue实现一个6个输入框的验证码输入组件
- np.reshape带给我的内存错误
- 详细描述一下 Elasticsearch 更新和删除文档的过程。
- Java如何将Ftp文件解压_ftp解压工具,ftp解压工具在java环境下配置其连接
- 最小化安装CentOS 7后,图形界面的安装(GNOME、KDE等)
- iframe:获取iframe中的元素
- SPSS调节效应检验(图文+数据集)【SPSS 045期】
- 软件行业的职位英文简称
- 谷歌地球看不了街景_PPT放入3D模型之后,居然能模拟谷歌地图!
- IPV6 阿里DDNS
- 黑灰对比可以为高大上网站风格代言
- PAT乙级-1051复数乘法(保留两位数-四舍五入)
- 微信小程序是否支持手机定位经纬度坐标
- 如何查阅NLP资料 转自https://blog.csdn.net/qq_27009517/article/details/80841146
- Basler相机环境配置
- python爬虫-爬取当当网书籍信息存到Excel中
- CreateJS-EaseJS 应用
- 系统集成项目管理工程师资料分享