SQL语句汇总(三)——聚合函数、分组、子查询及组合查询

https://www.cnblogs.com/ghost-xyx/p/3811036.html

SQL语句汇总(三)——聚合函数、分组、子查询及组合查询

拖了一个星期,终于开始写第三篇了。走起!

 

聚合函数:

SQL中提供的聚合函数可以用来统计、求和、求最值等等。

分类:

–COUNT:统计行数量

–SUM:获取单个列的合计值

–AVG:计算某个列的平均值

–MAX:计算列的最大值

–MIN:计算列的最小值

 

首先,创建数据表如下:

 

 

执行列、行计数(count):

标准格式

SELECT COUNT(<计数规范>) FROM <表名>

其中,计数规范包括:

- * :计数所有选择的行,包括NULL值;

- ALL 列名:计数指定列的所有非空值行,如果不写,默认为ALL;

- DISTINCT 列名:计数指定列的唯一非空值行。

例,计算班里共有多少学生:

SELECT COUNT(*) FROM t_student;

 

也可加入筛选条件,如求女学生数目:

SELECT COUNT(*) FROM t_student WHERE student_sex='女';

如果要计算班级数目,就需要用到DISTINCT:

SELECT COUNT(DISTINCT student_class) FROM t_student;

DISTINCT即去重,如果不加DISTINCT则结果为表行数——5。

 

返回列合计值(SUM):

注:sum只要ALL与DISTINCT两种计数规范,无*。

计算学生年龄之和:

SELECT SUM(student_age) FROM t_student;

 

返回列平均值(AVG):

计算学生平均年龄:

SELECT AVG(student_age)FROM t_student;

 

返回最大值/最小值(MAX/MIN):

求年龄最大的学生信息(最小值同理):

SELECT MAX(student_age) FROM t_student;

注:这里只能求出最大年龄,要想显示年龄最大的学生全部信息,需要用到之后的子查询。

 

数据分组(GROUP BY):

SQL中数据可以按列名分组,搭配聚合函数十分实用。

例,统计每个班的人数:

SELECT student_class,COUNT(ALL student_name) AS 总人数 FROM t_student GROUP BY (student_class);

AS为定义别名,别名的使用在组合及联接查询时会有很好的效果,之后再说。

分组中也可以加入筛选条件WHERE,不过这里一定要注意的是,执行顺序为:WHERE过滤→分组→聚合函数。牢记!

统计每个班上20岁以上的学生人数:

SELECT student_class,COUNT(student_name) AS 总人数 FROM t_student WHERE student_age >20 GROUP BY (student_class);

 

HAVING过滤条件:

之前说了分组操作、聚合函数、WHERE过滤的执行顺序,那如果我们希望在聚合之后执行过滤条件怎么办?

例,我们想查询平均年龄在20岁以上的班级

能用下面的语句吗?

SELECT student_class, AVG(student_age) FROM t_student WHERE AVG(student_age)>20 GROUP BY student_class;

结果会出错。正因为聚合函数在WHERE之后执行,所以这里在WHERE判断条件里加入聚合函数是做不到的。

这里使用HAIVING即可完成:

SELECT student_class,AVG(student_age) AS 平均年龄 FROM t_student GROUP BY (student_class) HAVING AVG(student_age)>20; 

 

这里再啰嗦一句

SQL的执行顺序:

–第一步:执行FROM

–第二步:WHERE条件过滤

–第三步:GROUP BY分组

–第四步:执行SELECT投影列

–第五步:HAVING条件过滤

–第六步:执行ORDER BY 排序

 

子查询:

为什么要子查询?

现有一数据表如下:

根据之前的知识我们可以查出每门科目的最高分,但是要想查出取得最高分的学生信息就做不到了。这时就需要用到子查询来取得完整的信息。

 

什么是子查询?子查询就是嵌套在主查询中的查询。

子查询可以嵌套在主查询中所有位置,包括SELECT、FROM、WHERE、GROUP BY、HAVING、ORDER BY。

但并不是每个位置嵌套子查询都是有意义并实用的,这里对几种有实际意义的子查询进行说明。

现有表两张:一张学生表、一张班表。id相关联

 

在SELECT中嵌套:

学生信息和班级名称位于不同的表中,要在同一张表中查出学生的学号、姓名、班级名称:

SELECT s.student_id,s.student_name,(SELECT class_name FROM t_class c WHERE c.class_id=s.class_id) FROM t_student s GROUP BY s.student_id;         

* 首先这条SQL语句用到了别名,写法为在FORM的表名后加上某个字符比如FROM t_student s,这样在之后调用t_student的某一列时就可以用s.student_id来强调此列来源于对应别名的那张表。

别名在子查询及联接查询中的应用有着很好效果,当两张表有相同列名或者为了加强可读性,给表加上不同的别名,就能很好的区分哪些列属于哪张表。

还有种情况就是在子查询或联接查询时,主查询及子查询均为对同一张表进行操作,为主、子查询中的表加上不同的别名能够很好的区分哪些列的操作是在主查询中进行的,哪些列的操作是在子查询中进行的,下文会有实例说明。

接下来回到上面的SQL语句中,可以看出本条子查询的嵌套是在SELECT位置(括号括起来的部分),它与学号、学生姓名以逗号分隔开并列在SELECT位置,也就是说它是我们想要查出的一列,

子查询中查出的是,班级表中的班级id与学生表中的班级id相同的行,注意 WHERE c.class_id=s.class_id 这里就是别名用法的一个很好的体现,区分开了两张表中同样列名的列。

结果:

最后的GROUP BY可以理解为对重复行的去重,如果不加:

 

在WHERE中嵌套:

现要查出C语言成绩最高的学生的信息:

SELECT * FROM t_student WHERE student_subject='C语言' AND student_score>=ALL (SELECT student_score FROM t_student WHERE student_subject='C语言') ;

结果:

这里出现了一个ALL,其为子查询运算符

分类:

–ALL运算符

  和子查询的结果逐一比较,必须全部满足时表达式的值才为真。

–ANY运算符

  和子查询的结果逐一比较,其中一条记录满足条件则表达式的值就为真。

–EXISTS/NOT EXISTS运算符

  EXISTS判断子查询是否存在数据,如果存在则表达式为真,反之为假。NOT EXISTS相反。

在子查询或相关查询中,要求出某个列的最大值,通常都是用ALL来比较,大意为比其他行都要大的值即为最大值。

要查出C语言成绩比李四高的学生的信息:

SELECT * FROM t_student WHERE student_subject='C语言' AND student_score >(SELECT student_score FROM t_student WHERE student_name='李四' AND student_subject='C语言'); 

通过上面两例,应该可以明白子查询在WHERE中嵌套的作用。通过子查询中返回的列值来作为比较对象,在WHERE中运用不同的比较运算符来对其进行比较,从而得到结果。

现在我们回到最开始的问题,怎么查出每门课最高成绩的学生的信息:

SELECT * FROM t_student s1 WHERE s1.student_score >= ALL(SELECT s2.student_score FROM t_student s2 WHERE s1.`student_subject`=s2.student_subject);

这里就是上文提到的别名的第二种用法,主、子查询对同一张表操作,区分开位于内外表中相同的列名。

结果:

 

子查询的分类:

–相关子查询

  执行依赖于外部查询的数据。

  外部查询返回一行,子查询就执行一次。

–非相关子查询

  独立于外部查询的子查询。

  子查询总共执行一次,执行完毕后后将值传递给外部查询。

 

上文提到的例子中,第一个例子求学生对应班级名的即为相关子查询,其中WHERE c.class_id=s.class_id 即为相关条件。其他的例子均只对一张表进行操作,为非相关子查询。

需要注意的是相关子查询主查询执行一回,子查询就执行一回,十分耗费时间,尤其是当数据多的时候。

 

组合查询:

通过UNION运算符来将两张表纵向联接,基本方式为:

SELECT 列1 , 列2 FROM 表1
UNION
SELECT 列3 , 列4 FROM 表2;

UNION ALL为保留重复行:

SELECT 列1 , 列2 FROM 表1
UNION ALL
SELECT 列3 , 列4 FROM 表2;

组合查询并不是太实用,所以这里只是简单提一下,不举出例子了。

 

上文说过相关子查询不推荐使用,组合查询又用的少之又少,那需要关联的多张表我们怎么做?

这就是下一篇博文要详细说明的SQL的重点表联接、联接查询。而此篇博文目的是为了对嵌套查询、别名的用法等等打下基础,毕竟只是写法变了,思路还是相似的。

 

感谢您的浏览,希望能对您有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/399675.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS应用国际化教程(2014版)

本文转载至 http://www.cocoachina.com/industry/20140526/8554.html 这篇教程将通过一款名为iLikeIt的应用带你了解最基础的国际化概念&#xff0c;并为你的应用添加国际化的支持。该示例应用有一个标签和一个You Like&#xff1f;按钮&#xff0c;用户无论何时点击You Like?…

公众平台商户接入(微信支付)功能申请教程

场景及类型介绍 商家可以申请公众账号支付和APP&#xff08;应用客户端&#xff09;支付两种接入微信支付方式。 公众账号支付&#xff1a;用户在微信公众帐号内使用微信支付消费&#xff0c;案例&#xff1a;易迅、QQ充值。 APP&#xff08;应用客户端&#xff09;支付&#x…

datatables 自定义按钮及响应点击事件

按钮 {"targets": -1,"class": "but_xq","data": null,"bSortable": false,"defaultContent": "<p><a id\"edit\" href "#\">修改</a > <a id\"del\" …

wxPython python3.x下载地址

2019独角兽企业重金招聘Python工程师标准>>> wxPython python3.x下载地址 http://wxpython.org/Phoenix/snapshot-builds/ 转载于:https://my.oschina.net/laugh2last/blog/504688

hadoop2.2.0 core-site.xml--security properties

<!--- security properties --> <property><name>hadoop.security.authorization</name><value>false</value><description>Is service-level authorization enabled?</description> </property> 注释&#xff1a; <…

【Python】python文件名和文件路径操作

Readme&#xff1a; 在日常工作中&#xff0c;我们常常涉及到有关文件名和文件路径的操作&#xff0c;在python里的os标准模块为我们提供了文件操作的各类函数&#xff0c;本文将分别介绍“获得当前路径”“获得当前路径下的所有文件和文件夹&#xff0c;”删除文件“&#xff…

WordPress 多媒体库添加分类和标签支持

https://www.xhsay.com/wordpress-attachment-taxonomies.html 时不时看到有朋友说 WordPress 这么强大的系统&#xff0c;怎么多媒体附件都不支持分类呢。好吧&#xff0c;目前默认的确是不支持的。今天推荐一款新的插件 Attachment Taxonomies&#xff0c;它可以为多媒体添加…

爬山算法和模拟退火算法简介(转)

源&#xff1a;爬山算法和模拟退火算法简介 一. 爬山算法 ( Hill Climbing ) 介绍模拟退火前&#xff0c;先介绍爬山算法。爬山算法是一种简单的贪心搜索算法&#xff0c;该算法每次从当前解的临近解空间中选择一个最优解作为当前解&#xff0c;直到达到一个局部最优解。 爬山算…

How to connect oracle databse

1. 下載客戶端Oracle Developer Tools for Visual Studio_32bit 安裝后通過配置tnsnames.ora指定連接 C:\app\user name\product\11.2.0\client_1\Network\Admin\SERVER(DESCRIPTION(ADDRESS(PROTOCOLTCP)(HOSTIP Address)(PORT1521))(CONNECT_DATA(SIDSID))) 重啓后可以在VS20…

window使用技巧记录

1.window选择指定区域的方法&#xff1a; 点击一个地方 ——> 按住shift键不放&#xff0c;点击另一个地方 ——> 这时候就会选择了这两个点作为矩形左上角和右下角的矩形区域 2. 当前目录下打开cmd窗口 按住shift键&#xff0c;右键&#xff0c;即可出现打开cmd的选项。…

wordpress列表页调用浏览器,wordpress显示文章浏览量!

1、把下面这段代码加在想显示文章浏览次数的位置&#xff08;例如模板内的content.php&#xff09; <?php setPostViews(get_the_ID()); echo getPostViews(get_the_ID()); ?> 2、如果需要在列表页显示查看次数&#xff0c;那么建议在列表页需要显示查看次数的位置单独…

一个例子看懂神马是闭包

闭包就是这个玩意儿。怎么用在此不做多讲。就告诉大家闭包长神马样子。 <!DOCTYPE html> <html> <head><title>神马JS闭包</title><meta http-equiv"Content-Type" content"text/html; charsetutf-8"><script>f…

关于找工作

1. 明确是什么公司&#xff1f; 2. 明确自己的工作职责&#xff1f; 3. 明确工作职责要求&#xff1f; 明确自己的职业规划 努力发展方向&#xff1a; 管理方向 English 外企转载于:https://www.cnblogs.com/dianyitongxiao/p/3586125.html

wordpress实现搜索页关键词高亮

http://www.hehaibao.com/wordpress-search-word-highlight/ 今天给网站搜索页加了关键词高亮功能&#xff0c;分享出来&#xff0c;希望对小伙伴们有所帮助。 实现效果如下图&#xff1a; 那么我们直接先上主要代码&#xff1a; 1 2 3 4 5 6 7 8 9 10 11<?php$s trim(ge…

[Leetcode] Majority Element 众数

Majority Element I Given an array of size n, find the majority element. The majority element is the element that appears more than ⌊ n/2 ⌋ times. You may assume that the array is non-empty and the majority element always exist in the array. 哈希表法 复杂…

数组和指针的区别

1、访问方式不同 ⑴数组的下标引用&#xff08;读一次内存&#xff09; char ary[5] "hello",c; ...... c ary[2]; ⑵对指针的引用&#xff08;读两次内存&#xff09; char *P,c; ...... c *p;   ⑶对指针进行下标引用&#xff08;读两次内存&#xff09; char…

SQL图像查看器 —— SQL Image Viewer

有时候往数据库里面存储了一些图片&#xff0c;但是如果不写读取程序的话&#xff0c;就不知道存储的对不对。 或者查看SQL数据库里面二进制看不懂&#xff0c;这个看图片很直观的。 就需要SQL Image Viewer这么一个?B的软件了 自己去找下载地址吧&#xff0c;我没有破解版。 …

wordpress 删除自定义字段

//删除自定义字段 global $wpdb; $wpdb->query( "DELETE FROM $wpdb->postmeta WHERE meta_key 友情链接-链接 " ); 添加在 主题的 functions.php 文件中&#xff0c;刷新后台&#xff0c;生效。

全局变量,extern和static以及命名空间的区别

全局变量&#xff0c;extern和static以及命名空间的区别全局变量只是在声明它的文件中有效&#xff0c;假如在另一个文件中声明定义了一个相同名称的全局变量&#xff0c;则在后续使用这两个变量的时候会产生名字上的冲突&#xff0c;解决的办法就是将其中一个全局变量的声明写…

Docker1.8在Centos7下的安装

1.创建docker的yum库[rootlocalhost~]# cd /etc/yum.repos.d/[rootlocalhostyum.repos.d]# vim docker.repo[dockerrepo]nameDockerRepositorybaseurlhttps://yum.dockerproject.org/repo/main/centos/7enabled1gpgcheck1gpgkeyhttps://yum.dockerproject.org/gpg&#xff08;2…