MySQL数据库7 - 汇总和分组数据
一 汇总和分组数据
查询语句 ---> 结果集(多条数据) ---> 聚合函数 ----> 单行记录
1.常用的聚合函数:
sum() 数字 对指定列中的所有非空值求总和
avg() 数字 对指定列中的所有非空值求平均值
min() 数字,字符,datetime 返回指定列中的最小数字,最早的日期或者最小的字符串
max() 数字,字符,datetime 返回指定列中的最大数字,最近的日期或者最大的字符集
count() 任意基于行的数据类型 统计结果集合众全部记录行的数量
例:查询玩家表中一共有多少名玩家信息
select count (user_qq) from users
select count(*) from users
例:查询QQ号是12301的玩家游戏的总分数
select sum(score) as '总分数' from scores where user_qq='12301'
例:查询QQ号是12302玩家的评价分数
select avg(score) as '平均分数’ from scores where user_qq='12302'
例:查询游戏编号的1的最高分数
select max(score) as '最高分数' from score where gno=1
例: 查询QQ号是12302的玩家的总分数,平均分数和最高分数
select sum(score) as '总分',avg(score) as '平均分',max(score) as '最高分' from scores where user_qq ='12302'
2. 使用GROUP BY分组
例:查询每个玩家的总分数,平均分数,最高分数
select sum(score) as '总分',avg(score) as '平均分',max(score) as '最高分' from scores group by user_qq
例: 查询每个玩家的平均分数,并显示玩家QQ号和平均分数
select user_qq, avg(score) as '平均分数' from scores group by user_qq
3. 筛选分组结果
在使用GROUP BY子句时,可用HAVING子句为分组统计进一步设置统计条件,HAVING子句与GROUP BY 子句的关系相当于WHERE子句与SELECT子句之间的关系
与WHERE子句的区别是,在HAVING子句中是以聚合函数的统计结果为筛选条件。
例:查询平均分数大于4000的玩家QQ号,总分数,平均分数
select user_qq, sum(score) as'总分数', avg(score) as '平均分数' from scores group by user_qq having avg(score) > 4000
例:查询所有用户的平均分数,和总分数,并按平均分数倒序排列
select user_qq,avg(score) as '平均分数' , sun(score) as '总分数' from scores group by user_qq orde by avg(score) desc
4.SELECT 语句的执行顺序
from 子句指定数据源
where 子句基于指定的条件对记录进行筛选
group by 子句将数据划分为多个分组
使用聚合函数进行计算
使用having子句筛选分组
使用order by 子句对结果集进行排序
二 连接查询
1. 多表连接
例:查询分数信息,显示玩家昵称,游戏名称和分数
select user_name as '昵称', game as '游戏名称' , score as '分数' from users.user_qq = scores.user_qq and game.gno= scores.gno
连接查询分为内连接和外连接两种
内连接特点:相连接的两张表地位平等
如果一张表中在另一张表中不存在对应数据,则不做连接
from 子句后面直接出现多个表名,这种连接方式即属于内连接,是隐式内连接
显示内连接格式:select col_list from table1[inner] join table2 on table1.col=table2.clo1
例:查询分数信息,显示玩家昵称,游戏名称和分数
select user_name as '昵称', g_name as '游戏名称', score as '分数' from games inner join scores on games.gno =scores.gno
inner join users on score.user_qq=user.user_qq
例:查询每个玩家的昵称,总分和平均分
select user_name as '昵称',sum(score) as '总分',avg(score) as '平均分' from users U inner join scores S on S.user_qq = U.user_qq group by U.user_qq,user_name
例:查询平均分数大于3500的分数信息,显示玩家昵称,总分数,平均分数,并按照平均分数降序排列
select user_name as '昵称',sum(score) as '总分',avg(score) as '平均分' from users U inner join scores S on S.user_qq = U.user_qq group by U.user_qq,user_name having avg(score)>3500 order by avg(score) desc
外连接分为左连接和右外连接
外连接特点:做连接的两个表地位不平等,其中有一张的基础表
基础表中的每条数据必须出现,即使另一张表中没有数据与之匹配,也要用NULL补齐
左外连接时左表是基础表,右表外连接时右表是基础表
语句中先出现的表为'左表', 后出现的表为'右表'
外连接格式: SELECT COL_LIST FROM TABLE1 LEFT/RIGHT[OUTER] JOIN TABLE2 ON TABLE1.COL=TABLE2.COL
例:查询所有玩家关于5号游戏的分数信息
select user_name as'昵称' gno as '游戏编号', score as '分数' from users U left join scores S on U.user_qq=S.user_qq and S.gno=5
MySQL数据库7 - 汇总和分组数据的更多相关文章
- MySQL 数据库操作命令汇总
此文全部都是基本的数据库语言 1.登陆到mysql >mysql -h hostname -u username -p 然后等待系统提示输入密码即可登陆.如果想在登陆的时候就选择好数据库,可以使 ...
- MySql数据库优化-汇总
各位,不喜勿喷,和气生财- 数据库优化,是一种综合性的技术,不是通过某一种方式让数据库效率提高很多,而是通过各个方面的优化,来是数据库效率明显的稳步的提高. 主要包括以下: 1.库表的设计优化(三种范 ...
- MySQL数据库— 汇总和分组数据
一 汇总和分组数据 查询语句 ---> 结果集(多条数据) ---> 聚合函数 ----> 单行记录 1.常用的聚合函数: sum() 数字 ...
- Shell脚本使用汇总整理——mysql数据库5.7.8以前备份脚本
Shell脚本使用汇总整理——mysql数据库5.7.8以前备份脚本 Shell脚本使用的基本知识点汇总详情见连接: https://www.cnblogs.com/lsy-blogs/p/92234 ...
- Shell脚本使用汇总整理——mysql数据库5.7.8以后备份脚本
Shell脚本使用汇总整理——mysql数据库5.7.8以后备份脚本 Shell脚本使用的基本知识点汇总详情见连接: https://www.cnblogs.com/lsy-blogs/p/92234 ...
- Linux上通过MySQL命令访问MySQL数据库时常见问题汇总
Linux上通过mysql命令访问MySQL数据库时常见问题汇总 1)创建登录账号 #创建用户并授权 #允许本地访问 create user 'test'@'localhost' identified ...
- .net连mysql数据库汇总
另外MySql官方出了一个在csharp里面连接MySql的Connector,可以试试 http://dev.mysql.com/downloads/#connector-net <add n ...
- MySQL 数据库备份种类以及常用备份工具汇总
1,数据库备份种类 按照数据库大小备份,有四种类型,分别应用于不同场合,下面简要介绍一下: 1.1完全备份 这是大多数人常用的方式,它可以备份整个数据库,包含用户表.系统表.索引.视图和存储过程等所有 ...
- mysql自身报错、java、reids连接mysql数据库报错汇总
1.Can't connect to local MySQL server through socket 'tmpmysql.sock' (2) 原因是mysql根本没有启动 2.Access den ...
随机推荐
- Apache Commons Lang
http://commons.apache.org/proper/commons-lang/javadocs/api-release/org/apache/commons/lang3/package- ...
- 了解真实的『REM』手机屏幕适配
rem 作为一个低调的长度单位,由于手机端网页的兴起,在屏幕适配中得到重用.使用 rem 前端开发者可以很方便的在各种屏幕尺寸下,通过等比缩放的方式达到设计图要求的效果. rem 的官方定义『The ...
- httplib用法
httplib的内容上是很多,也比较简单.以下是一个非常简单的例子,使用httplib获取google首页的html: import httplib conn = httplib.HTTPConnec ...
- Python学习笔记之字典
一.创建和使用字典 1.创建字典 phonebook={'Alice':'2341','Beth':'9102','Cecil':'3258'} 2.dict,通过映射创建字典 >>> ...
- css新增样式
一. box-shadow(阴影效果)使用:box-shadow: 20px 10px 0 #000;-moz-box-shadow: 20px 10px 0 #000;-webkit-box-sha ...
- js页面跳转(含框架跳转)整理
js方式的页面跳转1.window.location.href方式 <script language="javascript" type="text/java ...
- MySQL exists的用法介绍
有一个查询如下: 1 SELECT c.CustomerId, CompanyName 2 FROM Customers c 3 WHERE EXISTS( 4 SELECT Or ...
- hexo 本地local4000打不开解决方法
错误:Cannot GET /spadesq.github.io/ (注:spadesq.github.io是原来放hexo文件夹的名字) 由于我后来把hexo文件夹搬迁到别处,但我发现打开本地,地址 ...
- Java项目:学生成绩管理系统(一)
学生成绩管理系统(一) 项目名称:学生成绩管理系统 项目需求分析(Need 需求): (1)该系统的用户分为教师和学生.教师的功能有:管理某一学生或课程的信息以及成绩,包括增.删.查.报表打印等:学生 ...
- Reveal for mac延长30天试用的简单方法
在iOS逆向过程中经常使用Reveal来远程查看iOS平台应用的UI布局,但Reveal有30天使用限制,经常隔一段时间想使用的时候发现已经过期了,如图: 此时在OS X中打开命令行终端,输入以下命令 ...