mysql自字段、聚合和分组知识点

mysql自字段、聚合和分组知识点

ID:34724659

大小:112.68 KB

页数:3页

时间:2019-03-10

mysql自字段、聚合和分组知识点_第1页
mysql自字段、聚合和分组知识点_第2页
mysql自字段、聚合和分组知识点_第3页
资源描述:

《mysql自字段、聚合和分组知识点》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、MySQL字段控制、聚合和分组1 字段控制查询1.1 去除重复记录去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:SELECTDISTINCTsalFROMemp;1.2 查看雇员的月薪与佣金之和  因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不是数值类型,那么会出错。SELECT*,sal+commFROMemp;comm列有很多记

2、录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL。下面使用了把NULL转换成数值0的函数IFNULL:SELECT*,sal+IFNULL(comm,0)FROMemp;1.3 给列名添加别名在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total:SELECT*,sal+IFNULL(comm,0)AStotalFROMemp;给列起别名时,是可以省略AS关键字的:SELECT*,sal+IFNULL(comm,0)totalF

3、ROMemp;2 聚合函数聚合函数是用来做纵向运算的函数:lCOUNT():统计指定列不为NULL的记录行数;lMAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;lMIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;lSUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;lAVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;2.1 COUNT当需要纵向统计时可以使用COUNT()。l查询emp表中记录数:SELECTCOUN

4、T(*)AScntFROMemp;l查询emp表中有佣金的人数:SELECTCOUNT(comm)cntFROMemp;注意,因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数。l查询emp表中月薪大于2500的人数:SELECTCOUNT(*)FROMempWHEREsal>2500;l统计月薪与佣金之和大于2500元的人数:SELECTCOUNT(*)AScntFROMempWHEREsal+IFNULL(comm,0)>2500;l查询有佣金的人数,以及有领导的人数:SELECTCOUNT(co

5、mm),COUNT(mgr)FROMemp;2.2 SUM和AVG当需要纵向求和时使用sum()函数。l查询所有雇员月薪和:SELECTSUM(sal)FROMemp;l查询所有雇员月薪和,以及所有雇员佣金和:SELECTSUM(sal),SUM(comm)FROMemp;l查询所有雇员月薪+佣金和:SELECTSUM(sal+IFNULL(comm,0))FROMemp;l统计所有员工平均工资:SELECTSUM(sal),COUNT(sal)FROMemp;或者SELECTAVG(sal)FROMemp;2.3 MAX和MIN

6、l查询最高工资和最低工资:SELECTMAX(sal),MIN(sal)FROMemp;3 分组查询当需要分组查询时需要使用GROUPBY子句,例如查询每个部门的工资和,这说明要使用部分来分组。3.1 分组查询l查询每个部门的部门编号和每个部门的工资和:SELECTdeptno,SUM(sal)FROMempGROUPBYdeptno;l查询每个部门的部门编号以及每个部门的人数:SELECTdeptno,COUNT(*)FROMempGROUPBYdeptno;l查询每个部门的部门编号以及每个部门工资大于1500的人数:SELEC

7、Tdeptno,COUNT(*)FROMempWHEREsal>1500GROUPBYdeptno;3.2 HAVING子句l查询工资总和大于9000的部门编号以及工资和:SELECTdeptno,SUM(sal)FROMempGROUPBYdeptnoHAVINGSUM(sal)>9000;  注意,WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。