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 ...
随机推荐
- 网站行为跟踪 Website Activity Tracking Log Aggregation 日志聚合 In comparison to log-centric systems like Scribe or Flume
网站行为跟踪 Website Activity Tracking 访客信息处理 Log Aggregation 日志聚合 Apache Kafka http://kafka.apache.org/ ...
- Java Concurrency In Practice
线程安全 定义 A class is thread-safe if it behaves correctly when accessed from multiple threads, regardle ...
- Cisco路由器DHCP配置浅析
enable config terminal (进入配置模式) ip dhcp pool global(配置一个根地址池,global是地址池的名称,你可以采用有意义的字符串来表示) config ...
- 安装Centos 7操作系统
一.安装前准备 VMware workstation.CentOS-7-x86_64 系统镜像. 二.开始新建虚拟机 选择典型-下一步 选择稍后安装操作系统-下一步 选择LINUX-CentOS ...
- linux7开机自启动东方通tongweb
自启动服务: 可以通过把TongWeb设置为系统服务来实现. 具体实现: 以root用户进行操作,在/etc/init.d目录下编写TongWeb的服务脚本tongweb,用来控制TongWeb的启动 ...
- 浅谈 Python 的 with 语句(转)
add by zhj: 上下文管理器是对try-except-finally的再封装而已,只能算是优化代码这一级别的feature 原文:http://www.ibm.com/developerwor ...
- python创建进程的两种方式
1.方式1 import time import multiprocessing def task(arg): time.sleep(2) print(arg) def run(): # 进程1 p1 ...
- Django的model模型
一:字段选项 1,null =True 表示数据库的中可以存为null 默认值是False 2,blank=True 表示字段可以为空 默认值是False 3,chioces 由二项元组构成的一 ...
- DataUml Design 教程5-代码模板介绍(甚于T4模板技术)
DataUml Design 代码模板全然基于C#语言来编写的. 不懂写模板的能够请教作者,随时欢迎. 以下是一段模板代码,这段代码能够获取一个类结构的全部信息. <#@ ...
- 蛇形命名法(snake case)驼峰命名法(camel case)字符转换问题
描述小 Hi 写程序时习惯用蛇形命名法(snake case)为变量起名字,即用下划线将单词连接起来,例如:file_name. line_number.小 Ho 写程序时习惯用驼峰命名法(camel ...