一 汇总和分组数据

查询语句 ---> 结果集(多条数据) ---> 聚合函数  ----> 单行记录

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数据库— 汇总和分组数据的更多相关文章

  1. .net连mysql数据库汇总

    另外MySql官方出了一个在csharp里面连接MySql的Connector,可以试试 http://dev.mysql.com/downloads/#connector-net <add n ...

  2. MySQL数据库汇总

    -- mysql的最大连接数:默认为 100   -- mysql的增删改查   -- mysql统计各个字段(case when 用法 注:也可以使用其他的)   select (case when ...

  3. MySQL数据库7 - 汇总和分组数据

    一 汇总和分组数据 查询语句 ---> 结果集(多条数据) ---> 聚合函数  ----> 单行记录 1.常用的聚合函数: sum()         数字             ...

  4. Shell脚本使用汇总整理——mysql数据库5.7.8以前备份脚本

    Shell脚本使用汇总整理——mysql数据库5.7.8以前备份脚本 Shell脚本使用的基本知识点汇总详情见连接: https://www.cnblogs.com/lsy-blogs/p/92234 ...

  5. Shell脚本使用汇总整理——mysql数据库5.7.8以后备份脚本

    Shell脚本使用汇总整理——mysql数据库5.7.8以后备份脚本 Shell脚本使用的基本知识点汇总详情见连接: https://www.cnblogs.com/lsy-blogs/p/92234 ...

  6. Linux上通过MySQL命令访问MySQL数据库时常见问题汇总

    Linux上通过mysql命令访问MySQL数据库时常见问题汇总 1)创建登录账号 #创建用户并授权 #允许本地访问 create user 'test'@'localhost' identified ...

  7. MySQL 数据库备份种类以及常用备份工具汇总

    1,数据库备份种类 按照数据库大小备份,有四种类型,分别应用于不同场合,下面简要介绍一下: 1.1完全备份 这是大多数人常用的方式,它可以备份整个数据库,包含用户表.系统表.索引.视图和存储过程等所有 ...

  8. mysql自身报错、java、reids连接mysql数据库报错汇总

    1.Can't connect to local MySQL server through socket 'tmpmysql.sock' (2) 原因是mysql根本没有启动 2.Access den ...

  9. MySql数据库知识点

    关系型数据库管理系统简介 为什么使用数据库 1.降低存储数据的冗余度 2.更高的数据一致性 3.存储的数据可以共享 4.可以建立数据库所遵循的标准 5.便于维护数据完整性 6.能够实现数据的安全性 数 ...

随机推荐

  1. JVM总结之GC

    哪些内存需要回收 在Java堆中存放着几乎所有的对象实例,垃圾收集器在对堆进行回收前,第一件事情就是要知道哪些对象还"存活着",哪些对象已经"死去". 引用计数 ...

  2. Linux10分钟入门

    最近打算考红帽认证,将自己学习到的和工作中常用的一些命令进行总结,供初学者和一定基础的参考. 想系统性学习的话,还是建议看书(鸟哥的Linux私房菜)和看视频(基础版,推荐马哥和老男孩,不推荐**** ...

  3. H3CNE实验:通过Console端口本地访问H3C设备

    连接好Console线后,将交换机开机,在SecureCRT上会显示如下信息: Starting...... RAMLine.....OK System is booting............. ...

  4. winform利用委托delegate进行窗体间通信,相同标题已经存在??

    前段时间学习委托,感觉很模糊的样子,也做过许多实例,但是项目中一直没有用到,今天在项目中遇到一个很简单的例子,现在拿出来,做一个简单的记录. 要求:将弹出框里勾选的内容返回到主面板上. 工具:委托. ...

  5. javascript运动框架(三)

    迟到了好几天,不好意思哈!继续来优化一下javascript运动框架的代码.之前的代码存在bug,当重复点击时速度会加快,那么怎么解决这个bug呢? 现在我们就来解决一下,其实很简单,在开始运动时,关 ...

  6. hihocoder 1050 树中的最长路(动态规划,dfs搜索)

    hihocoder 1050 树中的最长路(动态规划,dfs搜索) Description 上回说到,小Ho得到了一棵二叉树玩具,这个玩具是由小球和木棍连接起来的,而在拆拼它的过程中,小Ho发现他不仅 ...

  7. Java List Remove时要注意的细节

    1.如果你是在遍历的时候去remove一个对象 for(int i = 0, length = list.size(); i<length; i++){} 这种遍历需要每次remove时,对i- ...

  8. 【微信小程序】wx.openLocation调取失败

    在调取地图的时候发现,wx.openLocation的方法在模拟器和安卓手机上都可以用,在苹果手机上报错. 报错为调取失败:fail invoke too frequently             ...

  9. Ambari安装之Ambari安装前准备(CentOS6.5)(一)

    优秀博客 <Ambari--大数据平台的搭建利器> Ambari安装前准备 (一)机器准备 192.168.80.144   ambari01 (部署Ambari-server和Mirro ...

  10. Android不编译某个模块

    Android 5.1 源码,编译相关的文件一般在build目录下build/target/product 放了很多mk文件:一般不同的产品会有不同的目录 假设我不想编译OpenWnn,在build目 ...