位置: IT常识 - 正文

MySQL 高级查询(MySQL高级查询)

编辑:rootadmin
MySQL 高级查询 目录1.左关联2.右关联3.子查询4.联合查询5.分组查询1.左关联

推荐整理分享MySQL 高级查询(MySQL高级查询),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:MySQL高级查询,mysql高级查询知识点,mysql高级查询作业,mysql高级查询大于某个值的数据,mysql 高级查询语句,mysql高级查询面试题,mysql高级查询试题,MySQL高级查询,内容如对您有帮助,希望把文章链接给更多的朋友!

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 gradeon school.id = grade.school_id;

运行结果:

这将返回一个结果集,其中包含所有年级及其所属学校信息, 如果年级没有对应的学校信息,则学校名称将显示为NULL。

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

注意:右关联和左关联的区别在于哪个表是主表和次要表,即 右关联的主表是年级表,次要表是学校表, 而左关联的主表是学校表,次要表是年级表。

3.子查询

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

现在,我们假设有两个表, 一个是学校表(school),包含学校的ID和名称, 另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

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

SELECT school_nameFROM schoolWHERE id IN ( SELECT school_id FROM grade WHERE grade_name = '三年级');MySQL 高级查询(MySQL高级查询)

运行结果:

这将返回一个结果集,其中包含所有包含名为"三年级"的年级的学校的名称。 子查询用于获取包含特定年级的学校ID, 主查询用于从学校表中检索对应的学校名称。

另一个示例是使用子查询和聚合函数检索每个学校的年级数。 例如,以下查询使用子查询和COUNT函数从"年级表"中获取每个学校的年级数, 并将其与"学校表"中的学校名称一起返回:

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

运行结果:

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

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

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

4.联合查询

MySQL中的联合查询(UNION)用于将多个SELECT语句的结果组合成一个结果集。 每个SELECT语句必须具有相同的列数和相似的数据类型, 而联合查询将自动对结果进行排序和去重。 可以使用UNION ALL来保留重复的行。

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

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

SELECT school_name FROM schoolUNIONSELECT grade_name FROM grade;

运行结果:

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

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

SELECT school_name, NULL AS grade_name FROM schoolUNIONSELECT 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_countFROMschool s LEFT JOIN grade g ON s.id = g.school_idGROUP BY s.id;

运行结果:

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

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

注意,在GROUP BY子句中使用了学校表的ID列,而不是名称列。 使用COUNT函数计算每个学校的年级数。

本文链接地址:https://www.jiuchutong.com/zhishi/295955.html 转载请保留说明!

上一篇:简单聊聊web3(简单聊聊太平天国)

下一篇:css关于文本溢出(css单行文本溢出隐藏)

  • iqoo8pro电池容量多大(iqoo8pro电池容量在哪里看)

    iqoo8pro电池容量多大(iqoo8pro电池容量在哪里看)

  • 苹果手机怎么能下载超过200m的东西(苹果手机怎么能不共享相册)

    苹果手机怎么能下载超过200m的东西(苹果手机怎么能不共享相册)

  • 微信头像更换影响收款吗(微信头像更换影响运气吗)

    微信头像更换影响收款吗(微信头像更换影响运气吗)

  • 手机充电只有一瞬间有反应(手机充电只有一种姿势能充上)

    手机充电只有一瞬间有反应(手机充电只有一种姿势能充上)

  • 电脑重装系统黑屏了怎么办(电脑重装系统黑屏只有鼠标)

    电脑重装系统黑屏了怎么办(电脑重装系统黑屏只有鼠标)

  • 苹果描述文件移除密码(苹果描述文件移除了就是删了吗)

    苹果描述文件移除密码(苹果描述文件移除了就是删了吗)

  • 微信的绿码在哪里(微信里绿码在哪里找)

    微信的绿码在哪里(微信里绿码在哪里找)

  • 苹果手机降低白点值要不要打开(苹果手机降低白点值调多少)

    苹果手机降低白点值要不要打开(苹果手机降低白点值调多少)

  • 苹果7灯怎么开(苹果7的灯开关在哪里)

    苹果7灯怎么开(苹果7的灯开关在哪里)

  • 抖音没有扫一扫(抖音没有扫一扫变成直播了)

    抖音没有扫一扫(抖音没有扫一扫变成直播了)

  • 电脑键盘下一行是哪个键(电脑键盘下一行怎么按)

    电脑键盘下一行是哪个键(电脑键盘下一行怎么按)

  • 华为mate10充电器功率(华为mate10充电器可以给苹果用吗)

    华为mate10充电器功率(华为mate10充电器可以给苹果用吗)

  • 为什么铁路12306无法人证核验(为什么铁路12306无法查询车次信息)

    为什么铁路12306无法人证核验(为什么铁路12306无法查询车次信息)

  • 苹果屏幕摔出绿色线条(苹果屏幕摔出绿线能修复吗)

    苹果屏幕摔出绿色线条(苹果屏幕摔出绿线能修复吗)

  • 安卓手机强制格式化(安卓手机强制格式化步骤)

    安卓手机强制格式化(安卓手机强制格式化步骤)

  • 华为emui10怎么申请内测(华为emui10升级申请)

    华为emui10怎么申请内测(华为emui10升级申请)

  • appstore无法面部识别(appstore面容)

    appstore无法面部识别(appstore面容)

  • 华为手表三个圈代表什么(华为手表三个圈的意思)

    华为手表三个圈代表什么(华为手表三个圈的意思)

  • 探探审核认证需要多久(探探审核认证需几天)

    探探审核认证需要多久(探探审核认证需几天)

  • 苹果手机不会自动熄屏(苹果手机不会自动切换wifi)

    苹果手机不会自动熄屏(苹果手机不会自动切换wifi)

  • 抖音管理员怎么设置(抖音管理员怎么设置心愿单)

    抖音管理员怎么设置(抖音管理员怎么设置心愿单)

  • 拨号助理怎么关闭(手机拨号出现拨号助理)

    拨号助理怎么关闭(手机拨号出现拨号助理)

  • msmgs.exe是什么进程 有什么作用 msmgs进程查询(msmpeng.exe 是什么)

    msmgs.exe是什么进程 有什么作用 msmgs进程查询(msmpeng.exe 是什么)

  • PHPCMS漏洞之文件poster.php(phpweb漏洞)

    PHPCMS漏洞之文件poster.php(phpweb漏洞)

  • 车辆出现质量问题
  • 其他综合收益包括资本公积吗
  • 分批付款 发票怎么开
  • 服务费和佣金的关系
  • 研发支出转入管理费用摘要
  • 应交税费待抵扣进项税额
  • 个税申报系统中年收入不超6万元的确认错了怎么改
  • 金税三期理解
  • 2016年红冲发票流程
  • 不经常发生应税行为的企业可以选择按小规模纳税人纳税
  • 免税投资背后的风险,你都清楚吗?
  • 取得的技术成果
  • 建筑 分包
  • 公益性捐赠的个税
  • 当月开发票收到货款会计应该以什么为做账凭证?
  • mac上安装homebrew
  • 价款包括增值税税率吗
  • 公司支付货款怎么做账
  • msdn原版win7
  • mac电脑command+s
  • 微软的客户主要是什么
  • 企业所得税涉税风险通知书
  • 其他业务收入与营业外收入
  • 商品先入库后得发票如何做账
  • 公司投资款无法收回
  • 无形资产使用寿命的复核
  • 非盈利组织盈利怎么办
  • 处理固定资产时的账务处理
  • 待处理流动资产净损失
  • swiper插件使用步骤
  • php实现文件上传需要使用哪个全局变量
  • php怎么样
  • vue中利用ref实现更灵活的子向父传值
  • php 输出
  • 税务三方协议怎么重签
  • 怎么理解中国实际
  • 财务咨询公司能出尽调报告吗
  • 红字发票申请单怎么开
  • 织梦如何添加浮动广告
  • 租金的支付期限是多久
  • 银行汇票用什么会计分录
  • win7系统安装包在哪个文件夹
  • pos机收款不开票怎么做账
  • 个人独资企业是小规模纳税人吗
  • 金税盘技术服务费怎么交费
  • 个体户年报纳税一般填多少合适
  • 财务费用应付利息
  • 餐饮不得抵扣进项税
  • 挂靠别人公司税怎么交?
  • 计提增值税如何做账
  • 所得税审核一般需要多久
  • 交易性金融资产的入账价值
  • 发票冲红的会计怎么处理
  • 暂估的应付账款需要调整报表吗
  • 研发收入超过研发成本
  • 没有销售收入月报怎么填
  • 用SELECT... INTO OUTFILE语句导出MySQL数据的教程
  • mysql常用功能
  • Mysql使用or如何优化
  • win7浏览器升级到ie11
  • qq8.2.1版本下载正式版
  • linux怎样挂载
  • 富士通FUJITSU笔记本电脑开机进入BIOS的方法(F2)
  • 电脑c盘里windows
  • windows.old文件夹有啥用
  • imac 迅雷
  • win7系统的一键还原怎么关闭
  • win8怎么安装微信
  • win7用户在哪
  • Win10 64位系统下QQ语音和QQ视频音量很小的两种解决方法
  • win7玩csgo掉帧怎么办
  • cocos按钮点击事件
  • shell调用java方法
  • jquery.inarray
  • 详解杭州亚运会会徽和口号
  • 宁波地铁支付宝可以刷吗
  • 江苏食品经营许可证企业端官网
  • 温州地方税务局
  • 江苏电子税务局电话
  • 上饶国资委领导班子成员名单
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设