mysql "order by" "distinct" "group by" "having"
本文用到的表结构
create table stu(
stu_id int auto_increment primary key,
name varchar(30) not null,
age smallint,
cls_id int
);
1、order by 排序 默认升序
1)单列排序,只按照某列排序
mysql> select name, age from stu order by name;
+-----------+------+
| name | age |
+-----------+------+
| guojing | 25 |
| huangrong | 23 |
| lisi | 20 |
| wangwu | 17 |
| xiaolongn | 14 |
| zhangsan | 18 |
| zhangsan | 18 |
| zhangsan | 15 |
| zhangsan | 17 |
| zhaoliu | 15 |
+-----------+------+
10 rows in set (0.00 sec)
2)多列排序,当第一列值相同时,按第二列排序,以此类推多列排序
mysql> select name, age from stu where name='zhangsan' order by name,age;
+----------+------+
| name | age |
+----------+------+
| zhangsan | 15 |
| zhangsan | 17 |
| zhangsan | 18 |
| zhangsan | 18 |
+----------+------+
4 rows in set (0.01 sec)
3)在要进行排序的字段后边添加。降序,"order by 字段 desc" 升序 "order by 字段 asc" 没有说明的将默认升序
mysql> select name, age from stu order by name desc, age asc;
+-----------+------+
| name | age |
+-----------+------+
| zhaoliu | 15 |
| zhangsan | 15 |
| zhangsan | 17 |
| zhangsan | 18 |
| zhangsan | 18 |
| xiaolongn | 14 |
| wangwu | 17 |
| lisi | 20 |
| huangrong | 23 |
| guojing | 25 |
+-----------+------+
10 rows in set (0.00 sec)
2、distinct 将查询的结果去掉重复值
mysql> select distinct name from stu;
+-----------+
| name |
+-----------+
| zhangsan |
| lisi |
| wangwu |
| zhaoliu |
| guojing |
| huangrong |
| xiaolongn |
+-----------+
7 rows in set (0.00 sec)
3、聚合函数
聚合函数也称分组函数,总共有5个:聚合函数忽略空值
- count 统计记录总数
- sum 求和
- avg 求平均值
- max 取最大值
- min 取最小值
1)求stu表的总记录数
mysql> select count(*) as 总记录数 from stu;
+--------------+
| 总记录数 |
+--------------+
| 7 |
+--------------+
1 row in set (0.00 sec)
2)求stu表的学生总最大值,最小值,平均值,年龄
mysql> select max(age) as 最大值, min(age) as 最小值, avg(age) as 平均值, sum(age) as 年龄总和 from stu;
+-----------+-----------+-----------+--------------+
| 最大值 | 最小值 | 平均值 | 年龄总和 |
+-----------+-----------+-----------+--------------+
| 25 | 14 | 18.8571 | 132 |
+-----------+-----------+-----------+--------------+
1 row in set (0.00 sec)
4、分组查询
分组查询中只能使用聚合函数与参与分组的字段
1)查询每个班的年龄最大值,最小值,平均值,总和
mysql> select cls_id, max(age), min(age), avg(age), sum(age) from stu group by cls_id;
+--------+----------+----------+----------+----------+
| cls_id | max(age) | min(age) | avg(age) | sum(age) |
+--------+----------+----------+----------+----------+
| 1 | 18 | 14 | 16.0000 | 32 |
| 2 | 25 | 17 | 21.0000 | 42 |
| 3 | 23 | 15 | 19.3333 | 58 |
+--------+----------+----------+----------+----------+
3 rows in set (0.00 sec)
2)查询每个班的人数
mysql> select cls_id, count(*) from stu group by cls_id;
+--------+----------+
| cls_id | count(*) |
+--------+----------+
| 1 | 2 |
| 2 | 2 |
| 3 | 3 |
+--------+----------+
3 rows in set (0.01 sec)
4、having
having子句用于分组后的数据筛选,不用where的原因是where不能和聚合函数一起使用,这里涉及到sql的执行顺序的问题
1)查找平均年龄大于18的班级
mysql> select cls_id, avg(age) from stu group by cls_id having avg(age) > 18;
+--------+----------+
| cls_id | avg(age) |
+--------+----------+
| 2 | 21.0000 |
| 3 | 19.3333 |
+--------+----------+
2 rows in set (0.00 sec)
mysql "order by" "distinct" "group by" "having"的更多相关文章
- mysql中函数DISTINCT,group by,CONCAT及GROUP_CONCAT的使用
一:DISTINCT 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是 ...
- mysql distinct&group by 应用
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...
- mysql 中order by 与group by的顺序
mysql 中order by 与group by的顺序 是: select from where group by order by 注意:group by 比order by先执行,order b ...
- mysql 去除重复 Select中DISTINCT关键字的用法 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是 distinct只能返回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用distinct不能解决的话,
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记 ...
- ORDER BY,GROUP BY 和DI STI NCT 优化
读<MySQL性能调优与架构设计>笔记之ORDER BY,GROUP BY 和DI STI NCT 优化 2015年01月18日 18:51:31 lihuayong 阅读数:2593 标 ...
- 转 SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题
SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题 SQL Union和SQL Union All用法 SQL UNION 操作符 UN ...
- mysql中select distinct的用法
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但 往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...
- Hive中笔记 :三种去重方法,distinct,group by与ROW_Number()窗口函数
一.distinct,group by与ROW_Number()窗口函数使用方法 1. Distinct用法:对select 后面所有字段去重,并不能只对一列去重. (1)当distinct应用到多个 ...
- mysql中去重 distinct 用法
在使用MySQL时,有时需要查询出某个字段不重复的记录,这时可以使用mysql提供的distinct这个关键字来过滤重复的记录,但是实际中我们往往用distinct来返回不重复字段的条数(count( ...
随机推荐
- flask路由中增加正则表达式
#coding=utf-8 from flask import Flask from werkzeug.routing import BaseConverter class RegexConverte ...
- java上传并压缩图片(等比例压缩或者原尺寸压缩)
本文转载自http://www.voidcn.com/article/p-npjxrbxr-kd.html 先看效果: 原图:1.33M 处理后:27.4kb 关键代码; package codeGe ...
- Ubuntu apt-get彻底卸载软件包
https://blog.csdn.net/get_set/article/details/51276609 如果你关注搜索到这篇文章,那么我可以合理怀疑你被apt-get的几个卸载命令有点搞晕了. ...
- PHP关于=>和->以及::的用法
1.=>的用法 在php中数组默认键名是整数,也可以自己定义任意字符键名(最好是有实际意义),如: $css=array('style'=>'0',‘color’=>‘green‘) ...
- WP8.1学习系列(第二十五章)——控件样式
XAML 框架提供许多自定义应用外观的方法.通过样式可以设置控件属性,并重复使用这些设置,以便保持多个控件具有一致的外观. 路线图: 本主题与其他主题有何关联?请参阅: 使用 C# 或 Visua ...
- 2017春季阿里大文娱(优酷)——C++研发一面
一.C++基础 1.1 sizeof 问题(空类.含虚函数.内存对齐) 1.2类构造的时候会默认生成哪些函数,C++11多了什么?(move,左\右值) 1.3为什么c++不类似java一样实现一个内 ...
- 重载i++,++i操作符
#include <iostream> using namespace std; class Time { public: Time(){min=;sec=;} Time(int m,in ...
- sencha touch 可自动增长高度TextArea
js代码如下: /* *高度自动增长的文本框 */ Ext.define('ux.TextArea', { extend: 'Ext.field.TextArea', xtype: 'autoText ...
- window上安装pymysql
date: 2018-11-26 18:54:04 安装: cmd: pip install pymysql 验证: cmd: python >>import pymysql 不报错即 ...
- FastDFS client for .net
fastDfs Code: https://code.google.com/p/fastdfs/ FastDfs_Client_DotNet:https://code.google.com/p/fas ...