当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL高级查询示例详细介绍

MySQL高级查询示例详细介绍

来源:脚本之家 2023-02-25 08:18:37 0浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《MySQL高级查询示例详细介绍》,这篇文章主要讲到MySQL高级查询等等知识,如果你对数据库相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

1.左关联

MySQL中的左关联(Left Join)是一种基于共同列的连接操作,

它将左侧表中的所有行与右侧表中匹配的行结合在一起,

如果右侧表中没有匹配的行,则结果集中右侧表中的所有列将显示为NULL。

左侧表是指在关键字LEFT JOIN中出现在关键字左侧的表。

下面是一个使用MySQL的LEFT JOIN进行连接操作的简单示例:

假设我们有两个表,一个是学校表(school),包含学校的ID和名称:

另一个是年级表(grade),包含年级的ID、学校ID和年级名称:

编程目标:我们可以使用以下代码来获取所有学校及其年级信息:

SELECT school.school_name as "学校名称", grade.grade_name as "年级名称"
FROM 
school LEFT JOIN grade ON school.id = grade.school_id;

运行结果:

这将返回一个结果集,其中包含所有学校及其年级信息,

如果学校没有年级,则年级名称将显示为NULL。

左关联操作确保我们可以获取所有学校的信息,即使它们没有年级数据。

2.右关联

MySQL中的右关联(Right Join)是一种基于共同列的连接操作,

它将右侧表中的所有行与左侧表中匹配的行结合在一起,

如果左侧表中没有匹配的行,则结果集中左侧表中的所有列将显示为NULL。

右侧表是指在关键字RIGHT JOIN中出现在关键字右侧的表。

右关联与左关联的区别在于哪个表是主表和次要表,

即右关联的主表是右侧表,次要表是左侧表,

而左关联的主表是左侧表,次要表是右侧表。

假设有两个表,一个是学校表(school),包含学校的ID和名称,

另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

编程目标:我们可以使用以下代码来获取所有学校及其年级信息:

select school.school_name as "学校名称", grade.grade_name as "年级名称"
from 
school right join grade
on school.id = grade.school_id;

运行结果:

这将返回一个结果集,其中包含所有年级及其所属学校信息,

如果年级没有对应的学校信息,则学校名称将显示为NULL。

右关联操作确保我们可以获取所有年级的信息,即使它们没有对应的学校数据。

注意:右关联和左关联的区别在于哪个表是主表和次要表,即

右关联的主表是年级表,次要表是学校表,

而左关联的主表是学校表,次要表是年级表。

3.子查询

MySQL中的子查询(Subquery)是一种在SELECT语句中使用的嵌套查询,用于从另一个查询的结果集中检索数据。子查询可以用作WHERE或HAVING语句中的条件,或者用作SELECT语句中的列。子查询可以返回单个值、一列值或一组行。

现在,我们假设有两个表,

一个是学校表(school),包含学校的ID和名称,

另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

编程目标:以下是一个使用子查询的示例,用于检索包含特定年级名称的学校列表:

SELECT school_name
FROM school
WHERE id IN (
  SELECT school_id
  FROM grade
  WHERE grade_name = '三年级'
);

运行结果:

这将返回一个结果集,其中包含所有包含名为"三年级"的年级的学校的名称。

子查询用于获取包含特定年级的学校ID,

主查询用于从学校表中检索对应的学校名称。

另一个示例是使用子查询和聚合函数检索每个学校的年级数。

例如,以下查询使用子查询和COUNT函数从"年级表"中获取每个学校的年级数,

并将其与"学校表"中的学校名称一起返回:

SELECT school.school_name, 
  (SELECT COUNT(*) 
   FROM grade 
   WHERE grade.school_id = school.school_id) as grade_count
FROM school;

运行结果:

这将返回一个结果集,

其中包含每个学校的名称和年级数。

子查询在内部查询中使用COUNT函数从年级表中检索与学校ID匹配的行数。

主查询用于从学校表中检索学校名称,并将子查询返回的年级数作为附加列一起返回。

4.联合查询

MySQL中的联合查询(UNION)用于将多个SELECT语句的结果组合成一个结果集。

每个SELECT语句必须具有相同的列数和相似的数据类型,

而联合查询将自动对结果进行排序和去重。

可以使用UNION ALL来保留重复的行。

假设有两个表,一个是学校表(school),包含学校的ID和名称,

另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

以下是一个使用UNION查询的示例,用于检索所有学校的名称和所有年级的名称,这些学校和年级存储在不同的表中:

SELECT school_name FROM school
UNION
SELECT grade_name FROM grade;

运行结果:

这将返回一个结果集,其中包含所有学校的名称和所有年级的名称。UNION操作将自动对结果集进行去重,并按名称排序。

如果要将学校和年级的名称分开,可以使用别名将两个SELECT语句的结果列重命名:

SELECT school_name, NULL AS grade_name FROM school
UNION
SELECT NULL AS school_name, grade_name FROM grade;

运行结果:

这将返回一个结果集,其中包含学校名称和年级名称的两个列。

注意,由于两个表中的名称列位于不同的位置,因此必须使用NULL作为占位符,以确保SELECT语句中的列数相同。

5.分组查询

MySQL中的分组查询(GROUP BY)用于将查询结果按照一个或多个列进行分组,并对每个分组应用聚合函数。GROUP BY子句必须跟在SELECT语句之后,并指定要分组的列名称。

假设有两个表,一个是学校表(school),包含学校的ID和名称,

另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

以下是一个使用分组查询的示例,用于检索每个学校的年级数:

SELECT school_name, COUNT(g.id) AS grade_count
FROM
school s LEFT JOIN grade g ON s.id = g.school_id
GROUP BY s.id;

运行结果:

这将返回一个结果集,其中包含每个学校的名称和年级数。

在这个查询中,使用LEFT JOIN将两个表连接起来,并使用GROUP BY子句按学校ID分组。

注意,在GROUP BY子句中使用了学校表的ID列,而不是名称列。

使用COUNT函数计算每个学校的年级数。

今天带大家了解了MySQL高级查询的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

版本声明
本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
mysql数据库中的索引类型和原理解读mysql数据库中的索引类型和原理解读
上一篇
mysql数据库中的索引类型和原理解读
Golang的锁机制使用及说明
下一篇
Golang的锁机制使用及说明
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    658次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    669次使用
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    691次使用
  • TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比
    TokenPony
    TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
    756次使用
  • 迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿
    迅捷AIPPT
    迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
    646次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码