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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 可以查询到一共有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)
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
关系型数据库 MySQL Java
centos7安装mysql教程及Navicat平替软件
【8月更文挑战第17天】本教程详述CentOS 7上安装MySQL的过程。首先确保移除任何预装的MySQL组件,然后通过wget获取并安装MySQL的YUM源。可以选择安装特定版本如5.7或8.0。安装MySQL服务器后,启动服务并查找初始密码。登录MySQL后应立即更改密码,并可根据需要设置远程访问权限。此外,还推荐使用免费开源的DBeaver作为数据库管理工具,提供了安装步骤以方便管理和操作MySQL数据库。
126 3
|
3天前
|
存储 SQL 关系型数据库
【入门级教程】MySQL:从零开始的数据库之旅
本教程面向零基础用户,采用通俗易懂的语言和丰富的示例,帮助你快速掌握MySQL的基础知识和操作技巧。内容涵盖SQL语言基础(SELECT、INSERT、UPDATE、DELETE等常用语句)、使用索引提高查询效率、存储过程等。适合学生、开发者及数据库爱好者。
13 0
【入门级教程】MySQL:从零开始的数据库之旅
|
21天前
|
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`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
25天前
|
关系型数据库 MySQL 数据库
MySQL的语法涵盖了数据定义、数据操作、数据查询和数据控制等多个方面
MySQL的语法涵盖了数据定义、数据操作、数据查询和数据控制等多个方面
49 5
|
2月前
|
SQL 关系型数据库 MySQL
MySQL】-DQL(基本、条件、分组、排序、分页)详细版
通过这些查询方法,你可以高效地检索、分析和组织MySQL数据库中的数据,以满足各种应用需求。实践中,理解这些SQL语句的基础知识以及它们如何组合起来进行复杂的数据操作是至关重要的。
36 1
|
2月前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
2月前
|
关系型数据库 MySQL 网络安全
MySQL主从复制详细教程
配置MySQL的主从复制是一个细致的过程,需要仔细遵循上述步骤进行。一旦配置完成并运行正常,主从复制将大大提高数据库的可用性和读写性能。在操作过程中,务必保持谨慎,确保数据的一致性和安全性。
272 0
|
3月前
|
关系型数据库 MySQL Linux
Docker安装mysql详细教程, mysqld: Can‘t read dir of ‘/etc/mysql/conf.d/‘(报错已解决)
Docker安装mysql详细教程, mysqld: Can't read dir of '/etc/mysql/conf.d/' (Errcode: 2 - No such file or directory) 已解决
|
3月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
221 3
|
3月前
|
关系型数据库 MySQL 调度
MySQL高级功能与优化策略深度探索
MySQL高级功能与优化策略深度探索

热门文章

最新文章