MySQL基础教程8——DQL—高级数据查询

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 可以查询到一共有1条数据,注意如果count(字段列表)中字段有空值是不会被记录到该条数据。

MySQL基础教程8——DQL—高级数据查询


MySQL基础教程8——DQL—高级数据查询


聚合函数


select 聚合函数(字段列表) from 表名;


count(统计数量)函数

mysql> select count(*) from user;
+----------+
| count(*) |
+----------+
|        1 |
+----------+
1 row in set (0.00 sec)

可以查询到一共有1条数据,注意如果count(字段列表)中字段有空值是不会被记录到该条数据。


例如:

+------+------+
| id   | name |
+------+------+
|    1 | Tom  |
|    2 | NULL |
+------+------+
mysql> select count(name) from user;
+-------------+
| count(name) |
+-------------+
|           1 |

可以看到有两条数据但是我们查询的是name字段,该字段中有一个空值,因此查询的结果只有一条。


max(最大值)函数

+------+------+
| id   | name |
+------+------+
|    1 | Tom  |
|    2 | NULL |
+------+------+
mysql> select max(id) from user;
+---------+
| max(id) |
+---------+
|       2 |
+---------+
1 row in set (0.02 sec)

查询字段id中的最大值为2。


min(最小值)函数

+------+------+
| id   | name |
+------+------+
|    1 | Tom  |
|    2 | NULL |
+------+------+
mysql> select min(id) from user;
+---------+
| min(id) |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)

查询字段id中的最小值为1。


sum(求和)函数

+------+------+
| id   | name |
+------+------+
|    1 | Tom  |
|    2 | NULL |
+------+------+
mysql> select sum(id) from user;
+---------+
| sum(id) |
+---------+
|       3 |
+---------+
1 row in set (0.00 sec)

计算所有id字段存储值的和。


avg(平均值)函数

+------+------+
| id   | name |
+------+------+
|    1 | Tom  |
|    2 | NULL |
| NULL | bom  |
+------+------+
mysql> select avg(id) from user;
+---------+
| avg(id) |
+---------+
|  1.5000 |
+---------+
1 row in set (0.00 sec)

注意: 字段中的空值不被记录总数因此也不参与平均值的计算。


分组查询


select 字段列表 from 表名 [where 条件] group by 分组字段名 [having 分组后过滤];

分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段没有意义。

+------+------+--------+
| id   | name | gender |
+------+------+--------+
|    1 | bom  | 男     |
|    2 | tom  | 男     |
|    3 | ming | 女     |
+------+------+--------+
mysql> select gender,count(*) from user group by gender;
+--------+----------+
| gender | count(*) |
+--------+----------+
| 女     |        1 |
| 男     |        2 |
+--------+----------+


排序查询


select 字段列表 from 表名 order by 字段1 排序方式1,字段2 排序方式2;

排序方式:asc(升序,默认值),desc(降序)

mysql> select * from user order by id asc;
+------+------+--------+
| id   | name | gender |
+------+------+--------+
|    1 | bom  | 男     |
|    2 | tom  | 男     |
|    3 | ming | 女     |
+------+------+--------+
3 rows in set (0.00 sec)
mysql> select * from user order by id desc;
+------+------+--------+
| id   | name | gender |
+------+------+--------+
|    3 | ming | 女     |
|    2 | tom  | 男     |
|    1 | bom  | 男     |
+------+------+--------+
3 rows in set (0.00 sec)


分页查询


select 字段列表 from 表名 limit 起始索引,查询记录数;


注意: 起始索引值从0开始。

mysql> select * from user limit 0,2;
+------+------+--------+
| id   | name | gender |
+------+------+--------+
|    1 | bom  | 男     |
|    2 | tom  | 男     |
+------+------+--------+
2 rows in set (0.00 sec)
mysql> select * from user limit 1,2;
+------+------+--------+
| id   | name | gender |
+------+------+--------+
|    2 | tom  | 男     |
|    3 | ming | 女     |
+------+------+--------+
2 rows in set (0.00 sec)
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
SQL 关系型数据库 MySQL
菜鸟之路Day30一一MySQL之DML&DQL
本文介绍了MySQL中DML(数据操作语言)和DQL(数据查询语言)的核心用法。DML主要包括插入(insert)、更新(update)和删除(delete)语句,通过具体示例演示了如何对表数据进行增删改操作。DQL则聚焦于数据查询,涵盖基本查询、条件查询、聚合函数、分组查询、排序查询和分页查询等内容。文章通过丰富的SQL语句实例,帮助读者掌握如何高效查询和操作数据库中的数据,适合初学者学习和实践。
604 12
|
9月前
|
安全 关系型数据库 MySQL
CentOS 7 yum 安装 MySQL教程
在CentOS 7上安装MySQL 8,其实流程很清晰。首先通过官方Yum仓库来安装服务,然后启动并设为开机自启。最重要的环节是首次安全设置:需要先从日志里找到临时密码来登录,再修改成你自己的密码,并为远程连接创建用户和授权。最后,也别忘了在服务器防火墙上放行3306端口,这样远程才能连上。
2202 16
|
存储 关系型数据库 MySQL
【免费动手教程上线】阿里云RDS MySQL推出大容量高性能存储:高性能本地盘(最高16TB存储空间)、高性能云盘(最高64TB存储空间)
阿里云RDS MySQL提供高性能本地盘与高性能云盘等存储方案,满足用户大容量、低延迟需求。高性能本地盘单盘最大16TB,IO延时微秒级;高性能云盘兼容ESSD特性,支持IO性能突发、BPE及16K原子写等能力。此外,阿里云还提供免费动手体验教程,帮助用户直观感受云数据库 RDS 存储性能表现。
|
监控 关系型数据库 MySQL
MySQL和SQLSugar百万条数据查询分页优化
在面对百万条数据的查询时,优化MySQL和SQLSugar的分页性能是非常重要的。通过合理使用索引、调整查询语句、使用缓存以及采用高效的分页策略,可以显著提高查询效率。本文介绍的技巧和方法,可以为开发人员在数据处理和查询优化中提供有效的指导,提升系统的性能和用户体验。掌握这些技巧后,您可以在处理海量数据时更加游刃有余。
1238 9
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
975 26
|
关系型数据库 MySQL Java
Servlet+MySQL增删改查 原文出自[易百教程] 转载请保留原文链接: https://www.yiibai.com/geek/1391
对于任何项目开发,创建,读取,更新和删除(CRUD)记录操作是应用程序的一个最重要部分。
437 20
|
tengine 关系型数据库 MySQL
Tengine、Nginx安装MySQL数据库命令教程
本指南详细介绍了在Linux系统上安装与配置MySQL数据库的步骤。首先通过下载并安装MySQL社区版本,接着启动MySQL服务,使用`systemctl start mysqld.service`命令。若启动失败,可尝试使用`sudo /etc/init.d/mysqld start`。利用`systemctl status mysqld.service`检查MySQL的服务状态,确保其处于运行中。通过日志文件获取初始密码,使用该密码登录数据库,并按要求更改初始密码以增强安全性。随后创建一个名为`tengine`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
NoSQL 关系型数据库 MySQL
MySQL与Redis协同作战:优化百万数据查询的实战经验
【10月更文挑战第13天】 在处理大规模数据集时,传统的关系型数据库如MySQL可能会遇到性能瓶颈。为了提升数据处理的效率,我们可以结合使用MySQL和Redis,利用两者的优势来优化数据查询。本文将分享一次实战经验,探讨如何通过MySQL与Redis的协同工作来优化百万级数据统计。
797 5

热门文章

最新文章

推荐镜像

更多