原创

📘 详解 DQL 查询语句:从基础到实战应用

温馨提示:
本文最后更新于 2025年07月22日,已超过 4 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

一、什么是 DQL?

DQL(Data Query Language,数据查询语言)是 SQL 的一部分,用于 从数据库中检索数据,不涉及数据修改操作。它的核心语句是 SELECT,通常配合 FROMWHEREGROUP BY 等子句使用 (CSDN博客)。

  • 用途:查看、分析与展示数据
  • 常见子句SELECT, FROM, WHERE, GROUP BY, HAVING, ORDER BY, LIMIT (CSDN博客)

二、DQL 基础语法

SELECT 列1, 列2, ...
FROM 表名
WHERE 条件
GROUP BY 列A
HAVING 条件
ORDER BY 列B ASC|DESC
LIMIT 起始行, 行数;

每个子句作用如下:

  1. FROM:指定查询的数据来源表
  2. WHERE:过滤行
  3. GROUP BY:将数据分组
  4. HAVING:对分组数据再筛选
  5. SELECT:选择输出列
  6. ORDER BY:排序结果
  7. LIMIT:分页控制 (CSDN博客, CSDN博客, CSDN博客)

执行顺序是固定的:
FROM → WHERE → GROUP BY → HAVING → SELECT → ORDER BY → LIMIT (CSDN博客)


三、常见用法示例

3.1 基础查询

SELECT name, age
FROM users
WHERE age >= 18;

3.2 聚合查询

SELECT department, COUNT(*) AS cnt, AVG(salary) AS avg_sal
FROM employees
WHERE active = 1
GROUP BY department
HAVING COUNT(*) > 5
ORDER BY avg_sal DESC;

3.3 联表查询(JOIN)

SELECT o.order_id, u.username, p.product_name
FROM orders o
JOIN users u ON o.user_id = u.id
LEFT JOIN products p ON o.product_id = p.id
WHERE o.created_at > '2025-01-01';

3.4 子查询

SELECT name
FROM users
WHERE id IN (SELECT user_id FROM orders WHERE total > 100);

四、实战应用技巧

✅ 优化效率

  • 利用索引提升 WHEREJOIN 的性能
  • 使用 EXPLAIN 分析查询计划
  • 避免在大表上扫全表,用精确过滤

✅ 数据可视化

如上图所示,对 SQL 执行计划可视化能帮助理解:

  • 把查询拆分阶段建图
  • 用工具如 DBeaver、Navicat 可视化 ER 图和关系链 (learnku.com)

✅ 实战练习

一个典型练习:

  1. 建表emp(id,name,gender,age,entrydate)
  2. 插入几条样本数据
  3. 练习查询:如分页查询 LIMIT,排序 ORDER BY,聚合 GROUP BY + HAVING 等 (CSDN博客)

五、进阶思考📈

- 子查询 vs JOIN 的选择

  • JOIN 性能更好,用于大表关联
  • 子查询更直观,适合复杂逻辑

- 使用窗口函数(Window Functions)

适用于排名、累积、滑动计算;MySQL 8+ 支持,例如:

SELECT username, score,
       RANK() OVER (ORDER BY score DESC) AS rank
FROM players;

六、图示与工具推荐

  • 执行计划图示可直观展现 SQL 分析流程 (CSDN博客, CSDN博客)
  • 推荐工具:MySQL Workbench、Navicat、DBeaver、Oracle SQL Developer 等,可助力可视化编辑与查询优化

七、小结

  • DQL 是 SQL 中最常用的部分,核心语句 SELECT 用于查询操作
  • 子句顺序固定:FROM→WHERE→GROUP BY→HAVING→SELECT→ORDER BY→LIMIT
  • 掌握联表、子查询、聚合操作并结合优化工具,是进阶数据库开发的基础
  • 定期训练、可视化分析、理解执行计划,帮助你成为 SQL 效率达人

延伸📚

  • MySQL DQL 实战示例教程 (ppmy.cn, CSDN博客)
  • 深入解析 DQL 子句和执行顺序 (CSDN博客)
  • 进阶:窗口函数、查询计划可视化、窗口函数使用等工具推荐

外链资源推荐


感谢阅读,欢迎点赞、收藏、转发支持原创!

正文到此结束
本文目录