【MySQL入门到精通-黑马程序员】MySQL基础篇-DQL

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记录。查询关键字:SELECT

一、DQL-介绍

DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记录。

查询关键字:SELECT


二、DQL-语法

06d8e0f05e511566be1ae63af1015159_f9c48f404d9647cdb4823858dc9c9d8b.png


二、DQL-基本查询

查询多个字段

SELECT 字段1,字段2,字段3...FROM 表名;

SELECT * FROM 表名;

注:开发中尽量不要用*,一是出于开发规范且不直观,二是使用*会影响效率。

设置别名

SELECT 字段1 [AS 别名1],字段2 [AS 别名2]...FROM 表名;

去除重复记录

SELECT DISTINCT 字段列表 FROM 表名;

三、DQL-条件查询

语法

SELECT 字段列表 FROM 表名 WHERE 条件列表;

条件

97a9554aff3c9a851c2b79ce41c66387_7868da606a7f40a4b4632aecb5c28430.png


四、DQL-聚合函数

介绍

将一列数据作为一个整体,进行纵向计算。


常见的聚合函数

aea312577ca7d40d88a415f40755e0a9_5d3548fb85b1412f9fcc0cd659011d63.png


语法

SELECT 聚合函数(字段列表) FROM 表名;

注:null值不参与所有聚合函数运算


五、DQL-分组查询

语法

SELECT 字段列表 FROM 表名 [WHERE 条件] GROUP BY 分组字段名 [HAVING 分组后过滤条件];

where与having区别

执行时机不同:where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤。

判断条件不同:where不能对聚合函数进行判断,而having可以。

注:

执行顺序:where > 聚合函数 > having。

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

六、DQL-排序查询

语法

SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1,字段2 排序方式2;

排序方式

ASC:升序(默认值)

DESC:降序

注:如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序。

七、DQL-分页查询

语法

SELECT 字段列表 FROM 表名 LIMIT 起始索引,查询记录数;

注:

起始索引从0开始,起始索引 = (查询页码 - 1) * 每页显示记录数。

分页查询是数据库的方言,不同的数据库有不同的实现,MySQL中是LIMIT。

如果查询的是第一页数据,起始索引可以省略,例如,查询第一页10条记录,直接简写为limit 10。

八、DQL-执行顺序

DQL-编写顺序与执行顺序

编写顺序

61ee5a15c12c497eb1d2231e4589215a_a26a320f29364438ba66b2a69784c4ce.png

执行顺序

202e398f18f3c37e86237e5ef99bc3b6_73e6f557024942f884ee8595d4c149f0.png

总结

06624edc0d6ae453d7669c8be77540d4_5c3084b332fc4beea3be1a59e1c68168.png

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
SQL 关系型数据库 MySQL
MySQL】-DQL(基本、条件、分组、排序、分页)详细版
通过这些查询方法,你可以高效地检索、分析和组织MySQL数据库中的数据,以满足各种应用需求。实践中,理解这些SQL语句的基础知识以及它们如何组合起来进行复杂的数据操作是至关重要的。
16 1
|
29天前
|
SQL 关系型数据库 MySQL
MySQL如何入门
MySQL如何入门
|
1月前
|
SQL 关系型数据库 MySQL
「Python入门」python操作MySQL和SqlServer
**摘要:** 了解如何使用Python的pymysql模块与MySQL数据库交互。首先,通过`pip install pymysql`安装模块。pymysql提供与MySQL的连接功能,例如创建数据库连接、执行SQL查询。在设置好MySQL环境后,使用`pymysql.connect()`建立连接,并通过游标执行SQL(如用户登录验证)。注意防止SQL注入,使用参数化查询。增删改操作需调用`conn.commit()`来保存更改。pymssql模块类似,但导入和连接对象创建略有不同。
37 0
「Python入门」python操作MySQL和SqlServer
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL从入门到精通】常用SQL语句分享
【MySQL从入门到精通】常用SQL语句分享
38 2
|
1月前
|
SQL 关系型数据库 MySQL
MySQL数据库—DQL查询语句(一篇教会你快速找到想要的数据)
MySQL数据库—DQL查询语句(一篇教会你快速找到想要的数据)
|
2月前
|
关系型数据库 MySQL 数据库
『Django』模型入门教程-操作MySQL
一个后台如果没有数据库可以说废了一半。日常开发中大多数时候都在与数据库打交道。Django 为我们提供了一种更简单的操作数据库的方式。 在 Django 中,模型(Model)是用来定义数据库结构的类。每个模型类通常对应数据库中的一个表,类的属性对应表中的列。通过定义模型,Django 的 ORM(Object-Relational Mapping)可以将 Python 对象映射到数据库表,并提供一套 API 来进行数据库操作。 本文介绍模型的用法。
|
1月前
|
SQL 关系型数据库 MySQL
MySQL DQL(数据查询语言)深度解析与实践
MySQL DQL(数据查询语言)深度解析与实践
|
1月前
|
存储 关系型数据库 MySQL
MySQL小白教程:从入门到查询高手
MySQL小白教程:从入门到查询高手
|
6天前
|
存储 关系型数据库 MySQL
MySQL——数据库备份上传到阿里云OSS存储
MySQL——数据库备份上传到阿里云OSS存储
23 0
|
1天前
|
SQL 存储 关系型数据库
数据库-MySQL-01(一)
数据库-MySQL-01(一)
13 4