位置: 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单行文本溢出隐藏)

  • 华为nova5怎么开不了机(华为nova5怎么开空调遥控器)

    华为nova5怎么开不了机(华为nova5怎么开空调遥控器)

  • 华为手机出现红色英文警告(华为手机出现红线条是怎么了)

    华为手机出现红色英文警告(华为手机出现红线条是怎么了)

  • soul上的头像绿点是啥意思(soul头像底下绿色的是什么)

    soul上的头像绿点是啥意思(soul头像底下绿色的是什么)

  • 怎么把快手变成夜间模式(怎么把快手变成大屏模式)

    怎么把快手变成夜间模式(怎么把快手变成大屏模式)

  • 魅族电量0充不进(魅族手机电量一直是0)

    魅族电量0充不进(魅族手机电量一直是0)

  • obu设备需要充电吗(obu设备充电线哪里有卖)

    obu设备需要充电吗(obu设备充电线哪里有卖)

  • qq群被别人举报封号怎么办(qq群被别人举报了怎么恢复)

    qq群被别人举报封号怎么办(qq群被别人举报了怎么恢复)

  • rank函数什么意思(rank函数是啥)

    rank函数什么意思(rank函数是啥)

  • 荣耀30s的屏幕(荣耀30s的屏幕是三星的吗)

    荣耀30s的屏幕(荣耀30s的屏幕是三星的吗)

  • w10笔记本要不要装杀毒

    w10笔记本要不要装杀毒

  • 手机信号出现e是怎么回事(手机信号出现edge)

    手机信号出现e是怎么回事(手机信号出现edge)

  • 电脑为什么有敲桌子的声音(电脑为什么敲不上字)

    电脑为什么有敲桌子的声音(电脑为什么敲不上字)

  • 文件保存不了怎么回事(文件保存不到电脑上怎么办)

    文件保存不了怎么回事(文件保存不到电脑上怎么办)

  • 鼠标一阵一阵的卡顿(鼠标一阵一阵的不动)

    鼠标一阵一阵的卡顿(鼠标一阵一阵的不动)

  • 宽带认证失败(宽带认证失败691)

    宽带认证失败(宽带认证失败691)

  • wps/reset按了一下家里没网了(wpsreset按了一下)

    wps/reset按了一下家里没网了(wpsreset按了一下)

  • iphone纯原机什么意思(iphone纯原和正品的区别)

    iphone纯原机什么意思(iphone纯原和正品的区别)

  • 不能连wifi的电视怎么投屏(不能连接wifi的电视可以看网络电视吗)

    不能连wifi的电视怎么投屏(不能连接wifi的电视可以看网络电视吗)

  • oppo手机怎样设置重启(oppo手机怎样设置下面三个按键)

    oppo手机怎样设置重启(oppo手机怎样设置下面三个按键)

  • 苹果11是单卡还是双卡(苹果11是单卡还是双卡手机)

    苹果11是单卡还是双卡(苹果11是单卡还是双卡手机)

  • 微型机中的硬盘属于(微型机的硬盘接口)

    微型机中的硬盘属于(微型机的硬盘接口)

  • 华为手机屏幕录制快捷键(华为手机屏幕录制文件保存在哪)

    华为手机屏幕录制快捷键(华为手机屏幕录制文件保存在哪)

  • 抖音视频如何调全屏(抖音视频如何调整播放速度)

    抖音视频如何调全屏(抖音视频如何调整播放速度)

  • 电脑忘记密码怎么开机(电脑忘记密码怎么重装系统)

    电脑忘记密码怎么开机(电脑忘记密码怎么重装系统)

  • k2p a1 a2区别(k2p a1 a2区别拆机)

    k2p a1 a2区别(k2p a1 a2区别拆机)

  • 优酷上传视频转码要多久(优酷上传视频转码是怎么操作)

    优酷上传视频转码要多久(优酷上传视频转码是怎么操作)

  • 以前年度无形资产本年摊销额
  • 当年亏损额为什么不能填?
  • 发票验旧以后还有用吗
  • 员工预支工资账务处理
  • 卖废品开发票开什么货物名称
  • 跨区预缴增值税怎么做账
  • 事业单位大型修缮会计分录
  • 公司借股东钱支付的利息如何做账?
  • 一次性离职补偿金如何避税
  • 更正申报所得税流程
  • 企业自用房要交契税吗
  • 转销无形资产的处置流程
  • 金穗开发票时怎样添加商品?
  • 单位向个人购买材料没有发票
  • 服务外包合同印花税
  • 公司购买的矿泉水属于什么科目
  • 文化事业建设费征收对象
  • 专票当月未认证怎么处理
  • 贴息收据税前扣除是什么
  • win8系统怎么连接无线
  • 房地产企业人防工程计入什么科目
  • 开启开发人员模式的方法
  • ahqinit.exe是什么进程 ahqinit是安全的进程吗
  • 收到员工违章操作罚款的会计分录
  • 麦克米伦anki
  • 蜜蜂 (© Angela Parker/Offset)
  • 资产评估中折现怎么算
  • 银行承兑汇票的付款人是谁?
  • 财政专户资金是专项资金吗
  • php字符串在另一个字符串出现
  • 酒吧会计要做些什么
  • react中路由有哪些常用组件
  • 3d沙盒游戏推荐
  • 个体户一直未申报会怎样
  • 期权增发是什么行业
  • php 文件处理
  • 小规模附加税减免政策2023
  • 哪些是生产企业
  • 如何处理预付和预付差异
  • 往来款项属于
  • 详解增发万亿国债细节
  • sql server 2005安装失败
  • 高新技术企业认定中介机构
  • 先买再卖影响可取现金吗
  • 企业所得税营业成本包括管理费用吗
  • 应付账款借方余额负数表示什么
  • 小企业固定资产折旧方法
  • 去税务局核定税种多久生效
  • 水利税费会计分录
  • 小企业会计准则适用于哪些企业
  • sql server错误和使用情况报告
  • 总结下半年工作计划
  • mysql 5.7.24安装
  • 新装mysql设置密码
  • windows怎么显示隐藏文件
  • win7设置繁体字
  • 蓝屏service
  • Win10 RedStone 2预览版14936快速版开始推送
  • winxp怎么装系统
  • mac系统文件名
  • win7旗舰版怎么改成专业版
  • 怎么调用windows api
  • 如何解决windows资源管理器已停止工作
  • 2016年Win10 RS1预览版11095已送交合作伙伴
  • linux怎么修改主配置文件
  • opengl阴影平移
  • linux的关闭命令
  • python语言基础与应用答案
  • jquery左右移动动画效果
  • 批处理查找字符中含有等号的子串
  • unity3d接入抖音广告api
  • Metaio in Unity3d 教学--- 二. 创建自己的Application
  • js初级教程
  • 中山市十大纳税大户
  • 不予税务行政许可
  • 顺丰快递的开票历史如何删除
  • 山东省国家税务局威海培训中心
  • 不明身份人员法律定义?
  • 印花税由哪方缴纳
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设