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

  • 怎么查自己名下的京东账号(怎么查自己名下有没有房产)

    怎么查自己名下的京东账号(怎么查自己名下有没有房产)

  • xsmax如何设置电池百分比(xsmax如何设置电量比)

    xsmax如何设置电池百分比(xsmax如何设置电量比)

  • 快手怎么突然变成新号了(快手怎么突然变模式了)

    快手怎么突然变成新号了(快手怎么突然变模式了)

  • 抖音私信图片保存不了(抖音私信图片保存看不到)

    抖音私信图片保存不了(抖音私信图片保存看不到)

  • cad图标不见了怎么办(cad图标不见了怎么办恢复)

    cad图标不见了怎么办(cad图标不见了怎么办恢复)

  • 属于因特网接入方式(以下所列的因特网接入技术中)

    属于因特网接入方式(以下所列的因特网接入技术中)

  • 华为手机用一会就发热是怎么回事(华为手机用一会就发烫是怎么回事)

    华为手机用一会就发热是怎么回事(华为手机用一会就发烫是怎么回事)

  • 陌陌拉黑是什么症状(陌陌拉黑有什么区别)

    陌陌拉黑是什么症状(陌陌拉黑有什么区别)

  • 关掉原彩显示省电吗(原彩显示关闭是啥意思)

    关掉原彩显示省电吗(原彩显示关闭是啥意思)

  • 小米手机更新系统后只显示mi(小米手机更新系统开不了机怎么办)

    小米手机更新系统后只显示mi(小米手机更新系统开不了机怎么办)

  • 小米10的屏幕是三星的么(小米10的屏幕是三星的吗)

    小米10的屏幕是三星的么(小米10的屏幕是三星的吗)

  • 索尼wf1000xm3怎么关机(索尼wf1000xm3怎么连接蓝牙)

    索尼wf1000xm3怎么关机(索尼wf1000xm3怎么连接蓝牙)

  • vivo手机主题换了为什么壁纸换不了(vivo的主题怎么更换)

    vivo手机主题换了为什么壁纸换不了(vivo的主题怎么更换)

  • 微信未授权抖音怎么办(微信未授权抖音登录失败)

    微信未授权抖音怎么办(微信未授权抖音登录失败)

  • 淘宝分身怎么下载(下载手机淘宝分身)

    淘宝分身怎么下载(下载手机淘宝分身)

  • 优酷可以同时登录几个(优酷app怎么登录)

    优酷可以同时登录几个(优酷app怎么登录)

  • iphonexsmax有快充功能吗(iponexsmax支持快充)

    iphonexsmax有快充功能吗(iponexsmax支持快充)

  • excel2010新建工作簿默认有几个(Excel2010新建工作薄的默认名称为工作薄1)

    excel2010新建工作簿默认有几个(Excel2010新建工作薄的默认名称为工作薄1)

  • 12306买票支持京东白条吗(12306买不了去北京的票)

    12306买票支持京东白条吗(12306买不了去北京的票)

  • 微信朋友圈怎么用(微信朋友圈怎么@一个人)

    微信朋友圈怎么用(微信朋友圈怎么@一个人)

  • 微信漂流瓶没有了吗(微信漂流瓶没有了玩什么)

    微信漂流瓶没有了吗(微信漂流瓶没有了玩什么)

  • 苹果xsmax微信美颜怎么开(苹果xsmax微信美颜突然消失)

    苹果xsmax微信美颜怎么开(苹果xsmax微信美颜突然消失)

  • 怎么查银行预留手机号(怎么查银行预留信息)

    怎么查银行预留手机号(怎么查银行预留信息)

  • iphone xs max参数(iphone xs max参数太平洋)

    iphone xs max参数(iphone xs max参数太平洋)

  • 小米8充满电要多久(小米8充满电多久)

    小米8充满电要多久(小米8充满电多久)

  • qq权限怎么取消(qq权限怎么取消不了)

    qq权限怎么取消(qq权限怎么取消不了)

  • 手机cpu性能排行榜天梯图最新2022年6月(手机cpu性能排行榜2023最新天梯图)

    手机cpu性能排行榜天梯图最新2022年6月(手机cpu性能排行榜2023最新天梯图)

  • 以前年度损益调整属于哪类科目
  • 现金折扣的销售额
  • 本月开的发票次月预缴如何做会计分录呢?
  • 哪些发票不可进行进项税抵扣?
  • 公司合并后业务怎么办
  • 营改增后预交营业税怎么处理
  • 管理人员工资计入管理费用吗
  • 应付账款扣款怎么做账
  • 退货没有红字发票怎么办
  • 待认证发票后面需要做附件吗
  • 企业所得税中准予扣除的损失
  • 小规模纳税人计提增值税账务处理
  • 生产的废料怎么做账
  • 企业增加值的计算
  • 暂估成本比实际高分录
  • 上月材料入库会计分录
  • php获取远程文件扩展名
  • navione.exe是什么意思
  • 购物卡怎么给
  • lnmgr.exe是什么
  • 退回已修改是什么意思
  • 开票逃税的处罚
  • 微前端架构实现
  • 投资者追加资本金属于什么
  • 进项税额销项税额
  • 增值税怎样交
  • 基础土建工程是干什么的
  • 织梦数据库连接失败的原因
  • python删除列表的方法
  • php接口技术
  • 港资企业属于什么性质
  • 用jdom创建中文的xml文件的方法
  • SQL Server中的XML数据进行insert、update、delete
  • 建筑劳务单位
  • sql server 新增字段
  • 接受捐赠如何进项
  • 利润表中本月数,本期金额指什么
  • 简易计税指的是增值税吗
  • 无形资产减值准备借贷方向增减
  • 承兑到期没兑现怎么办
  • 房租费待摊分录怎么做
  • 工程预付款是否含规费和税金
  • 两个公司之间怎么走账
  • 收到项目资本金怎么入账
  • 走逃失联企业管理办法
  • 购置税 过户
  • 公司自建房要交房产税吗
  • 融资租赁可以折旧吗
  • 未达起征点可以申请一次性创业补贴吗
  • 研发费用资本化条件
  • 发票作废了还能恢复吗?
  • sql解析原理
  • sqlserver1053怎么解决
  • mysql改表名语句
  • 让Windows Server 2008系统安全更上一层楼
  • windowsxp的安装方法
  • 如何查看winxp系统的运行内存
  • ubuntu系统应用
  • win7系统卸载360
  • Linux利用sftp命令传输文件(极少数人知道的方法)
  • linux系统怎么复制文件到u盘
  • win7如何设置关机快捷方式
  • windows10 禁用u盘
  • shell脚本语言入门
  • android PercentRelativeLayout 支持百分比来设置控件的宽高
  • 经典都有什么
  • node-red 全局变量
  • Node.js中的事件循环是什么样的
  • angularjs2
  • android自定义listview
  • webview清除数据
  • ubuntu修改默认桌面环境
  • javascript基础入门视频教程
  • 面向对象的程序设计语言是
  • python中私有函数调用方法解密
  • jquery设置背景颜色
  • 发票代码和发票号码有什么区别
  • 青海国税发票查询系统
  • 医院网上预约号怎么取消
  • 丰田威驰2023款1.5自动挡新车报价
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设