MySQl数据库第八课-------SQL命令查询-------主要命脉2

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS AI 助手,专业版
RDS Agent(兼容OpenClaw),2核4GB
简介: MySQl数据库第八课-------SQL命令查询-------主要命脉

排序   order by

默认为升序 (从小到大)

--写法1
select * from city  where order by `id`;
--写法2
select * from city  where order by `id` asc;

ec05a1bba26d431281e989b860506ff6.png

对id进行排序

降序(从大到小)

select * from city  where order by `id` desc;


334360a676f54212a04854b70910be1e.png

多个字段进行排序
select * from city order by `pid`desc, `id`asc;

意思是,优先对字段pid进行排序,排完之后,如果有相同pid数据的再进行id排序,如果没有pid相同的数据就不会进行id排序

5c5e7c2e20ec4a64bbbfe5ebb0c739e3.png

聚合

统计个数
-- 统计总数
select count(*) from table_name;
select count(0) from table_name;
-- 统计id大于3的人数
select count(0) from table_name where id >3;
--计算某个字段的数据量
select conut(`字段名`) from 表名 ;

细心的小可爱就会发现count()可以填 *   、数字、字段名    ,下面我来一一讲解一下

count(`字段名`):对这个字段进行计数,如果该字段存在有空值,就不会计算进去,简单理解为只计算非空的数据个数

count(*):会对每一条数据里面的字段值一一遍历一次判断,会造成很大的性能浪费,返回数据的条数

count(数字) :不会对每一条数据里面的字段一一遍历判断,只要写到数据表的每一条数据都会被计算进去,所以建议使用conut(数字)而不是conut(*),

注意一下 conut(数字)里的数字是随意的

最大值

-- 最大值
select max(id) from table_name;
-- 性别为女的最大ID
select max(id) from table_name where gender='女';

 

最小值

-- 最小值
select min(id) from table_name;
-- 性别为男的最小ID
select min(id) from table_name where gender='男';

 

求和 sum()

-- 求和
select sum(age) from table_name;
-- 性别为男的年龄总值
select sum(age) from table_name where gender='男';

记住count 和sum是不一样的  count是计算数量的  sum是计算和的

 

平均数 avg()

-- 平均值
select avg(age) from table_name;
-- 性别为男的年龄平均值
select avg(age) from table_name where gender='男';
select sum(age)/count(0) from table_name where gender='男';

86ca5d9e73224c759b7ea11afd1d9e6f.png

求平均值还可以这样写

select sum(`字段名`)/count(`字段名`) from 表名 ;

分组:group by

注意一下,对哪个字段进行分组,就只能查看那个字段,当写入的字段不参与分组会报错

将查询结果按照字段进行分组,字段值相同的为一组。可用于单个字段分组,也可用于多个字段分组

简单理解就是相同的为一组,比如在一个班级上有很多人。按兴趣分组,相同爱好的为一组,

-- 性别分组
select gender from table_name group by gender;
-- 利用分组去重
select id, name from table_name group by id, name;
-- 这里的去重是利用group by进行去重,它的效率会比distinct快,但是要求将进行去重的字段全部写入
--分组内

54546e071fab4f7a850f5edd9c7e52d8.png

使用分组也会产生去重效果,

计算分组后,各组里的人数

select `字段名`,count(0)from 表名 group by `字段名`;

dccef3085ee046e683265f1349adce56.png

如果要加where判断条件的话就要写在group by前面

select * from city where `id`> 3 order by `id`;
分组后的字端拼接
-- 分组后的字段拼接
select gender, group_concat(name) from table_name group by gender;
select gender, concat(name) from table_name group by gender;

457eca28586e41ddbb415679ced9c292.png

所谓的字段拼接就是在分组后,我们可以理解为收集该组成员的某样特征

select `pid` ,group_concat(`name`),count(0) from(select * from city limit 4)as a  group by `pid` order by `pid`;

bb27cc4746e84a2d8e30b9004390501b.png

括号里面的意思就是获取city表的前四条数据 取别名为a,然后对a表的pid字段进行分组  ,并然后进行升序排序和进行name字段的拼接,

-- 分组后的聚合
-- 各个性别的人数
select gender, count(0) from table_name group by gender;
-- 各个性别的平均年龄
select gender, avg(age) from table_name group by gender;

with rollup       coalesce()

局部求和
-- 使用coalesce代替空值
select coalesce(gender, 'total'), count(0) num from table_name group by gender -
- with rollup;

with rollup 用于局部的聚合,能把某个相同字段值的个数进行统计,并以null命名

coalesce(字段名,‘name’)把字段名里的空值改为name

结果筛选 having

-- 分组后的条件筛选
-- 各个性别的平均年龄大于10的数据
select gender, avg(age) from table_name group by gender having avg(age) >10;
-- 各个性别的平均年龄大于10的人数
select gender, count(0) from table_name group by gender having avg(age) >10;

where 是对初始值进行筛选

having 是对结果值进行筛选

总结

如果写where 条件就要写在筛选出结果之前,比如写在group by前面,因为where是初始值进行筛选,where写在后面就相当于对结果进行筛选了,

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
9月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1467 152
|
9月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
1068 156
|
9月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
728 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
8月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
416 6
|
9月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
9月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
9月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
842 11
|
9月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
616 8
|
9月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
570 158
|
9月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。

热门文章

最新文章

推荐镜像

更多