[MySQL]常用函数,统计函数,分组查询和过滤,以及子查询

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 哈喽,大家好!我是保护小周ღ,本期为大家带来的是 MySQL 数据库常用函数,以及分组查询和子查询数据表的基本操作:创建、删除、修改表,针对修改表的结构进行了讲解,随后是如何向数据表中添加数据,浅浅的提了一下表中数据的查询,更多相关知识敬请期待:保护小周ღ *★,°*:.☆( ̄▽ ̄)/$:*.°★*

哈喽,大家好!我是保护小周ღ,本期为大家带来的是 MySQL的常用函数,统计函数,分组查询和过滤,以及子查询,更多相关知识敬请期待:保护小周ღ *★,°*:.☆( ̄▽ ̄)/$:*.°★*

一、函数

1.1 常用函数(了解)

--数学运算SELECTABS(-8)  --绝对值SELECTCEILING(9.4) --向上取整SELECTFLOOR(9.4) --向下取整SELECTROUND(3.1415926,2)
--重要SELECTrand()  --生成一个随机数--字符串函数SELECTCHAR_LENGTH('你好') --字符串长度SELECTCONCAT('你','好') --字符串拼接SELECTLOWER('HELLO') --字符串转换成小写SELECTUPPER('hello') --字符串转换成大写--时间和日期函数SELECTCURRENT_DATE() --获取当前日期--重要SELECTSYSDATE() --获取当前日期时间

1.2 统计函数|聚合函数|分组函数(常用)(掌握)

--简单使用SELECTSUM(`sal`) AS总和FROMempSELECTAVG(`sal`) AS平均值FROMempSELECTMAX(`sal`) AS最大值FROMempSELECTMIN(`sal`) AS最小值FROMempSELECTCOUNT(`sal`) AS计数FROMemp;
--同时显示多个SELECTSUM(`sal`) ,
AVG(`sal`) 平均值,
MAX(`sal`) 最大值,
MIN(`sal`) 最小值,
COUNT(`sal`) 个数FROMemp;
--聚合函数支持哪些类型SELECTSUM(ename), AVG(ename)
FROMempSELECTSUM(hiredate), AVG(hiredate)
FROMempSELECTMAX(ename),MIN(ename)
FROMempSELECTMAX(hiredate),MIN(hiredate)
FROMempSELECTCOUNT(ename)
FROMemp;
SELECTCOUNT(comm)
FROMemp;
--count()
SELECTCOUNT(mgr) fromemp; --Count(指定列,字段)会忽略所有的null值--本质都是计算行数,count*把所有列都计算一遍,count1是把所有的行都变成1返回一个结果SELECTCOUNT(*) fromemp; --不会忽略null值SELECTCOUNT(1) fromemp; --不会忽略null值

二、 分组查询和过滤(掌握)

--查出所有员工的平均工资selectavg(sal)
fromemp--我想根据不同的部门看一下不同部门的平均工资

image.png

group by 字句语法

select列(要求出现在groupby的后面),分组函数fromwhere筛选条件groupby分组的列表orderby字句--注意:查询列表比较特殊,要求是分组函数和groupby后出现的字段
--简单的分组查询--查出每个工种的最高工资SELECTjob,MAX(sal)
fromempGROUPBYjob;
--查出每个部门的人数SELECTdeptno, COUNT(*)
fromempGROUPBYdeptno--查询每个岗位的平均工资SELECTjob,avg(sal) 
FROMscott.empGROUPBYjob;
--查询每个部门中每个岗位的人数和平均工资SELECTdeptno,job,count(*),avg(sal) 
FROMscott.empGROUPBYdeptno,job;
--分组前查询--查出每个岗位名称带E的人数个数SELECTjob,count(*)
FROMscott.empWHEREenamelike'%E%'GROUPBYjob--查询除去财务部门外不同部门名称的最高薪资,最低薪资,平均薪资SELECTdname, MAX(sal), MIN(sal),AVG(sal)
fromdeptdINNERJOINempeond.deptno=e.deptnowheredname!='财务'GROUPBYd.dname--分组后查询--查询哪个部门的员工个数<6SELECTdeptno, count(*)
fromempGROUPBYdeptnoHAVINGCOUNT(*) <6--查询每个部门的人数,只显示4人以上的部门SELECTdeptno,count(*)
FROMscott.empGROUPBYdeptnoHAVINGcount(*)>4;
--查询每个岗位中名字包含E的员工人数,只显示超过2人的岗位和人数SELECTjob,count(*)
FROMscott.empWHEREenamelike'%E%'GROUPBYjobHAVINGcount(*)>2;
--分组后查询,查询不同部门名称的最高薪资,最低薪资,平均薪资,平均薪资大于900SELECTdname, MAX(sal),MIN(sal),AVG(sal)fromdeptdINNERJOINempeond.deptno=e.deptnoGROUPBYd.dnameHAVINGMIN(sal) >900--总结:--聚合函数count、sum、avg、max、min等不能在where子句中使用。--where语句先执行过滤,having语句后执行过滤--WHERE后面不允许写分组函数,HAVING后面不允许写未分组的字段--查询除了财务部门外不同部门的最高薪资,最低薪资,平均薪资且平均薪资大于900SELECTdname, MAX(sal), MIN(sal),AVG(sal)
fromdeptdINNERJOINempeond.deptno=e.deptnowheredname!='财务'GROUPBYd.deptnoHAVINGMIN(sal) >900--查询出各个分组里面的工作人员SELECTdname, GROUP_CONCAT(ename)
fromdeptdINNERJOINempeond.deptno=e.deptnoGROUPBYd.dname

三、子查询(掌握)

  • 1.一般来说,连接查询都可以用子查询替换。
  • 2. 相对于表连接,子查询适合于作为查询的筛选条件。
  • 3. where(值是固定的,这个值是计算出来的)
  • 4. 本质:==在where语句中嵌套一个查询语句==
--子查询|嵌套查询--执行顺序由里到外--子查询返回一个值--innerjoin展示两个表的表头信息,子查询展示一个表的信息--查询销售的所有员工(员工编号,员工姓名)
SELECTempno, ename, dnamefromempeINNERJOINdeptdone.deptno=d.deptnowhered.dname='销售'--查询销售的所有员工(员工编号,员工姓名)
SELECTempno, enamefromempewheredeptnoin (SELECTdeptnofromdeptwheredname='销售')
--查询在广州工作的员工中,哪些人的名字中包含有E,要求显示员工姓名和部门编号SELECTename, deptnofromempwheredeptno= (selectdeptnofromdeptwhereloc='广州') andenamelike'%E%'--查询SMITH的领导姓名SELECTenameFROMscott.empWHEREempno=(SELECTmgrFROMscott.empWHEREename='SMITH');
--查询编号是7521,7566,7654,7698,7782的员工,哪些是BLAKE的下属SELECT*FROMempWHEREempnoin (7521,7566,7654,7698,7782) andmgr= (selectempnofromempwhereename='blake')
--查询KING的下属哪位在上海工作,要求显示员工编号,员工姓名,岗位,领导工号,部门编号SELECTempno, ename, job, mgr, deptnoFROMempWHEREdeptno= (selectdeptnofromdeptwhereloc='上海') andmgr= (selectempnofromempwhereename='king')    
--子查询返回多个值--查询北京和上海的所有员工信息SELECT*FROMscott.empWHEREdeptnoin(SELECTdeptnoFROMscott.deptWHERElocin('北京','上海'));
--查询KING的工资占公司总工资的比例SELECT (SELECTsalFROMscott.empWHEREename='KING')/(SELECTsum(sal) FROMscott.emp) FROMdual;
SELECTsal/(SELECTsum(sal) FROMscott.emp) FROMscott.empWHEREename='KING';


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
1月前
|
SQL 缓存 监控
MySQL缓存机制:查询缓存与缓冲池优化
MySQL缓存机制是提升数据库性能的关键。本文深入解析了MySQL的缓存体系,包括已弃用的查询缓存和核心的InnoDB缓冲池,帮助理解缓存优化原理。通过合理配置,可显著提升数据库性能,甚至达到10倍以上的效果。
|
1月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
12天前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
储存过程(Stored Procedures) 和 函数(Functions) : 储存过程和函数允许用户编写 SQL 脚本执行复杂任务.
116 14
|
14天前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
以上概述了MySQL 中常见且重要 的几种 SQL 查询及其相关概念 这些知识点对任何希望有效利用 MySQL 进行数据库管理工作者都至关重要
59 15
|
1月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
1月前
|
SQL 关系型数据库 MySQL
MySQL入门指南:从安装到第一个查询
本文为MySQL数据库入门指南,内容涵盖从安装配置到基础操作与SQL语法的详细教程。文章首先介绍在Windows、macOS和Linux系统中安装MySQL的步骤,并指导进行初始配置和安全设置。随后讲解数据库和表的创建与管理,包括表结构设计、字段定义和约束设置。接着系统介绍SQL语句的基本操作,如插入、查询、更新和删除数据。此外,文章还涉及高级查询技巧,包括多表连接、聚合函数和子查询的应用。通过实战案例,帮助读者掌握复杂查询与数据修改。最后附有常见问题解答和实用技巧,如数据导入导出和常用函数使用。适合初学者快速入门MySQL数据库,助力数据库技能提升。
|
1月前
|
SQL 监控 关系型数据库
MySQL高级查询技巧:子查询、联接与集合操作
本文深入解析了MySQL高级查询的核心技术,包括子查询、联接和集合操作,通过实际业务场景展示了其语法、性能差异和适用场景,并提供大量可复用的代码示例,助你从SQL新手进阶为数据操作高手。
|
1月前
|
安全 关系型数据库 MySQL
MySQL安全最佳实践:保护你的数据库
本文深入探讨了MySQL数据库的安全防护体系,涵盖认证安全、访问控制、网络安全、数据加密、审计监控、备份恢复、操作系统安全、应急响应等多个方面。通过具体配置示例,为企业提供了一套全面的安全实践方案,帮助强化数据库安全,防止数据泄露和未授权访问,保障企业数据资产安全。
|
15天前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
53 3
|
21天前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。

热门文章

最新文章

推荐镜像

更多