mysql数据库优化课程---10、mysql数据库分组聚合
mysql数据库优化课程---10、mysql数据库分组聚合
一、总结
一句话总结:select concat(class,' 班') 班级,concat(count(*),' 人') 人数 from user group by class;
select class,max(id),min(id),count(*),sum(id),avg(id) from user group by class;
count(*)
group by class
1、为什么操作系统要选择linux?
很多开源产品
a、开源产品或者不开源产品的第一版都是linux,windows做不到
b、没有界面的黑屏系统能够极大的节约资源,windows开机就占了1-2g的内存,windows内存释放有问题,你电脑开机几天就要重启,服务器的话也是开了几天就卡了,linux就不会,linux的回收机制还是比较强大的
c、因为linux开源,旗下的很多开源的产品,而且这些开源的产品最开始的版本也是在linux下的,甚至很多都不会发布windows版本
2、mysql随机数函数怎么使用?
order by rand()
3、mysql如何从一个表中随机取一条数据?
order by rand() limit 1
select * from user order by rand() limit 1;
4、mysql统计函数的两种方法?
count(*)
count(id)
select count(*) from user;
select count(id) from user;
5、分组聚合怎么使用?
group by class字段
按照班级的字段进行分组‘
在分组的情况下,聚合是聚合的分组的数据
统计每个班的总人数:
mysql> select concat(class,' 班') 班级,concat(count(*),' 人') 人数 from user group by class;
user表数据:
+----+----------+----------+-------+
| id | username | password | class |
+----+----------+----------+-------+
| 1 | user1 | 123 | 1 |
| 2 | user2 | 123 | 1 |
| 3 | user3 | 123 | 1 |
| 4 | user4 | 123 | 2 |
| 5 | user5 | 123 | 1 |
| 6 | user6 | 123 | 3 |
| 7 | user7 | 123 | 2 |
| 8 | user8 | 123 | 1 |
| 9 | user9 | 123 | 3 |
| 10 | user10 | 123 | 1 |
+----+----------+----------+-------+
group by分组聚合的使用:
#按条件进行分组,然后在分组的基础上进行有条件的聚合.
把每个班的第一个人取出来:
mysql> select * from user group by class;
+----+----------+----------+-------+
| id | username | password | class |
+----+----------+----------+-------+
| 1 | user1 | 123 | 1 |
| 4 | user4 | 123 | 2 |
| 6 | user6 | 123 | 3 |
+----+----------+----------+-------+
统计每个班的总人数:
mysql> select concat(class,' 班') 班级,concat(count(*),' 人') 人数 from user group by class;
+--------+--------+
| 班级 | 人数 |
+--------+--------+
| 1 班 | 6 人 |
| 2 班 | 2 人 |
| 3 班 | 2 人 |
+--------+--------+
6、统计每个班的总人数?
count(*)
group by class
select concat(class,' 班') 班级,concat(count(*),' 人') 人数 from user group by class;
+--------+--------+
| 班级 | 人数 |
+--------+--------+
| 1 班 | 6 人 |
| 2 班 | 2 人 |
| 3 班 | 2 人 |
+--------+--------+
二、内容在总结中
随机数rand函数:
select * from user order by rand() limit 1;
统计个数count函数:
#统计表总行数:
select count(*) from user;
select count(id) from user;
#统计符合条件的行数:
select count(*) from user where id>2;
求和sum():
select sum(id) from user;
平均值avg():
select avg(id) from user;
最大值max():
select max(id) from user;
最小值min():
select min(id) from user;
user表数据:
+----+----------+----------+-------+
| id | username | password | class |
+----+----------+----------+-------+
| 1 | user1 | 123 | 1 |
| 2 | user2 | 123 | 1 |
| 3 | user3 | 123 | 1 |
| 4 | user4 | 123 | 2 |
| 5 | user5 | 123 | 1 |
| 6 | user6 | 123 | 3 |
| 7 | user7 | 123 | 2 |
| 8 | user8 | 123 | 1 |
| 9 | user9 | 123 | 3 |
| 10 | user10 | 123 | 1 |
+----+----------+----------+-------+
group by分组聚合的使用:
#按条件进行分组,然后在分组的基础上进行有条件的聚合.
把每个班的第一个人取出来:
mysql> select * from user group by class;
+----+----------+----------+-------+
| id | username | password | class |
+----+----------+----------+-------+
| 1 | user1 | 123 | 1 |
| 4 | user4 | 123 | 2 |
| 6 | user6 | 123 | 3 |
+----+----------+----------+-------+
统计每个班的总人数:
mysql> select concat(class,' 班') 班级,concat(count(*),' 人') 人数 from user group by class;
+--------+--------+
| 班级 | 人数 |
+--------+--------+
| 1 班 | 6 人 |
| 2 班 | 2 人 |
| 3 班 | 2 人 |
+--------+--------+
补充:
-----------------------------------------------
分组聚合:
select class,max(id),min(id),count(*),sum(id),avg(id) from user group by class;
+-------+---------+---------+----------+---------+---------+
| class | max(id) | min(id) | count(*) | sum(id) | avg(id) |
+-------+---------+---------+----------+---------+---------+
| 1 | 10 | 1 | 6 | 29 | 4.8333 |
| 2 | 7 | 4 | 2 | 11 | 5.5000 |
| 3 | 9 | 6 | 2 | 15 | 7.5000 |
+-------+---------+---------+----------+---------+---------+
mysql数据库优化课程---10、mysql数据库分组聚合的更多相关文章
- mysql数据库优化课程---3、数据库设计是什么
mysql数据库优化课程---3.数据库设计是什么 一.总结 一句话总结: 就是设计各个字段及各个字段类型 1.char,varchar,text同存'ABC'的存储空间为多少? char(255): ...
- mysql数据库优化课程---1、数据库的本质是什么
mysql数据库优化课程---1.数据库的本质是什么 一.总结 一句话总结: 文件夹-文件:一个数据库其实就是一个的文件夹,数据库里面的表就是文件夹里的一个或者多个文件(根据数据库引擎不同而不同,My ...
- mysql数据库优化课程---9、php用什么写的
mysql数据库优化课程---9.php用什么写的 一.总结 一句话总结:php是用c语言写的,所以php里面的那些模块什么都是c语言 c 1.php用什么写的? c php是用c语言写的,所以php ...
- mysql数据库优化课程---16、mysql慢查询和优化表空间
mysql数据库优化课程---16.mysql慢查询和优化表空间 一.总结 一句话总结: a.慢查询的话找到存储慢查询的那个日志文件 b.优化表空间的话可以用optimize table sales; ...
- mysql数据库优化课程---15、mysql优化步骤
mysql数据库优化课程---15.mysql优化步骤 一.总结 一句话总结:索引优化最立竿见影 1.mysql中最常用最立竿见影的优化是什么? 索引优化 索引优化,不然有多少行要扫描多少次,1亿行大 ...
- mysql数据库优化课程---14、常用的sql技巧
mysql数据库优化课程---14.常用的sql技巧 一.总结 一句话总结:其实就是sql中那些函数的使用 1.mysql中函数如何使用? 选择字段 其实就是作用域select的选择字段 3.转大写: ...
- mysql数据库优化课程---13、mysql基础操作
mysql数据库优化课程---13.mysql基础操作 一.总结 一句话总结:mysql复制表,索引,视图 1.mysql如何复制表? like select * 1.复制表结构 create tab ...
- mysql数据库优化课程---12、mysql嵌套和链接查询
mysql数据库优化课程---12.mysql嵌套和链接查询 一.总结 一句话总结:查询user表中存在的所有班级的信息? in distinct mysql> select * from cl ...
- mysql数据库优化课程---11、mysql普通多表查询
mysql数据库优化课程---11.mysql普通多表查询 一.总结 一句话总结:select user.username,user.age,class.name,class.ctime from u ...
随机推荐
- 第二课作业——redis常用命令
第二课时作业 静哥 by 2016.2.23~2016.2.22 [作业描述] 1.key string list hash结构中,每个至少完成5个命令,包含插入 修改 删除 查询,list 和h ...
- maven的核心概念
1 简单的核心概念 1.1 坐标 groupId.artifactId.version,很简单,这三个坐标定位到了该依赖的位置,有了它们就可以下载该依赖了. 1.2 依赖 如果一个jar包使用了另外一 ...
- 使用CocoaPods配置管理开源项目
今天从GitHub下载了MMProcessHUB,想先看看demo,但是不巧的是作者是用CocoaPods配置的,需要安装CocoaPods,CocoaPods是一个第三方的类库管理工具.找了一篇很详 ...
- 自动适应label
CGFloat btnH = 300; NSString *text=@"你在这是NSString的对象方法,一个字符串实例调用该方法时,方法会通过传入的参数返回一个CGRect型数据,这个 ...
- emo前端
1 点击按钮可以在form中添加input控件,以name给input编号,然后点击按钮ajax上传表单,在回调函数中弹框显示结果: <form id="newfriends" ...
- Python 实现获取【昨天】【今天】【明天】日期
昨天 from datetime import date, timedelta yesterday = (date.today() + timedelta(days=-1)).strftime(&qu ...
- Redis配置文件的使用
Redis基本配置 常规配置 进到配置文件下 vi /etc/redis.conf 写入配置项 port 1111 # 配置端口号 daemonize yes # 是否后台运行 daemonize y ...
- Django框架错误处理
错误处理 在一些网站开发中.经常会需要捕获一些错误,然后将这些错误返回比较优美的界面,或者是将这个错误的请求做一些日志保存.那么我们本节就来讲讲如何实现. 常用的错误码: 404:服务器没有指定的ur ...
- Java Synchronized 与 ThreadLocal 异同
同:都是为了线程安全 异:synchronized是利用锁的机制,使变量或代码块在某一时该只能被一个线程访问.而ThreadLocal为每一个线程都提供了变量的副本, 使得每个线程在某一时间访问到的并 ...
- Tomcat的session
创建session 在具体说明session的创建过程之前,先看一下BS访问模型: browser发送Http request: tomcat内核Http11Processor会从HTTP requ ...