位置: 编程技术 - 正文

MySQL中表子查询与关联子查询的基础学习教程(mysql子查询效率如何)

编辑:rootadmin

推荐整理分享MySQL中表子查询与关联子查询的基础学习教程(mysql子查询效率如何),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql单表子查询,mysql查询字段出现子查询,mysql单表子查询,mysql子查询语句,mysql 子表查询,mysql子查询写法,mysql子查询写法,mysql子查询写法,内容如对您有帮助,希望把文章链接给更多的朋友!

MySQL 表子查询表子查询是指子查询返回的结果集是 N 行 N 列的一个表数据。MySQL 表子查询实例下面是用于例子的两张原始数据表:article 表:

blog 表:

SQL 如下:

查询返回结果如下所示:

该 SQL 的意义在于查找 article 表中指定的字段同时也存在于 blog 表中的所有的行(注意 = 比较操作符换成了 IN),实际上等同于下面的条件语句:

实际上,后面的语句是经过 MySQL 优化的而效率更高,或者也可以使用 MySQL JOIN 表连接来实现。在此使用该例子只是为了便于描述表子查询的用法。

MySQL 关联子查询关联子查询是指一个包含对表的引用的子查询,该表也显示在外部查询中。通俗一点来讲,就是子查询引用到了主查询的数据数据。以一个实际的例子来理解关联子查询:article 文章表:

MySQL中表子查询与关联子查询的基础学习教程(mysql子查询效率如何)

user 用户表:

我们要查出 article 表中的数据,但要求 article 中的某个或某些字段与 user 表字段有逻辑关系(本例为 uid 相等)。SQL 语句如下:

返回查询结果如下:

将该例 SQL 与如下语句比较更能看出关联子查询与普通子查询的区别:

在本实例中,虽然两个 SQL 执行后的返回结果都一样,但它们的实现过程是完全不一样的。后者(普通子查询)实际被执行为:

但在关联子查询中,是无法单独执行子查询语句的。其实际流程大致为:

先做外部主查询; 将主查询的值传入子查询并执行; 子查询再将查询结果返回主查询,主查询根据返回结果完成最终的查询。

这个执行流程类似于 EXISTS 子查询,实际上某些情况下 MySQL 就是将关联子查询重写为 EXISTS 子查询来执行的。

MySQL 关联子查询效率很明显,一般情况下关联子查询的效率是比较低下的,实际上本例中的关联子查询例子也仅是为了演示关联子查询的原理及用法。如果可以的话,关联子查询尽量使用 JOIN 或其他查询来代替。如本例中,使用 INNER JOIN 来替换的 SQL 为:

注意:此处只是为了演示用 INNER JOIN 替换关联子查询的样例,并非表名这种处理是最优处理。

深入解析半同步与异步的MySQL主从复制配置 简单来讲MySQL的主从复制就是一个C/S架构的应用。master可以认为是我们通常意义上所认为的server,slave可以当作是一台client。slave上的I/O线程去请求master

简单整理MySQL的日志操作命令 1.首先确认你日志是否启用了MySQLshowvariableslike'log_bin';如果启用了,即ON那日志文件就在MySQL的安装目录的data目录下2.怎样知道当前的日志MySQLshowmasterstatus

深入解析MySQL的事务隔离及其对性能产生的影响 SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的。低级别的隔离级一般支持更高的并发处理

标签: mysql子查询效率如何

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

上一篇:MySQL的子查询中FROM和EXISTS子句的使用教程(在mysql中子查询是)

下一篇:简单整理MySQL的日志操作命令(mysql常见操作)

  • 出口退税申报系统安装路径
  • 水电费进项税转出填在哪一栏位
  • 自来水安装增值税税率
  • 已知不含税金额和税额怎么求税率
  • 自己提供原材料让别人加工
  • 集团公司收到的发票
  • 营业利润为负数说明什么
  • 商贸运费核算到几号结束
  • 车船发票什么样子
  • 行政单位在建工程入账
  • 城建税教育附加地方教育附加的税率
  • 价内税和价外税名词解释
  • 存货周转天数一般在多少为合适
  • 当月不抵扣的增值税发票在发票勾选时怎么操作
  • 企业所得税地方分成比例
  • 工程款分配方式
  • 股东退股未分配股利
  • Win11如何设置快捷键调音量
  • 预付款多长时间
  • 商业银行的票据贴现业务与票据抵押贷款业务的区别
  • msp 什么意思
  • php require的用法
  • 银行承兑汇票背书人和被背书人什么关系
  • php根据日期判断星座
  • 电脑中的guest账户在哪里
  • PHP简单实现HTTP和HTTPS跨域共享session解决办法
  • 什么是主营业务税金及附加
  • 企业中秋晚会主持词
  • electron 打包
  • 抄税的步骤
  • 支付个人赔偿款入账
  • 数字图像处理课后题答案
  • AttributeError: cannot assign module before Module.__init__() call
  • 美国大学数学系排名
  • php远程访问
  • 餐厅如何计提固定成本
  • 农产品免税收入怎么做账
  • 小企业会计准则应付税款法
  • 转账错误被退款怎么处理
  • 土地补偿款会议纪要
  • 担保公司代偿会上征信嘛
  • 赠品视同销售价格如何确定
  • mysql的服务器
  • 本年利润和利润分配属于什么账户
  • 以前年度的应收账款收不回来怎么办
  • 工资个税什么时候用综合所得公式计算
  • 生产车间为生产产品
  • 公司现金收付管理
  • 餐饮行业采购
  • 代销手续费如何做分录
  • 冲个人借款分录怎么写
  • 当月只有进项票没有销项票怎么办
  • 余利宝和余额宝哪一个安全
  • 应收款钱已收回会计分录
  • 免抵退税额账务处理办法
  • 分配现金股利的顺序
  • 销售酒怎么结转销售成本
  • 发票要不回来怎么办
  • 异地成立子公司能用母公司的名称吗?
  • 公司被私募基金收购有啥影响 裁员
  • mysql关联语句
  • ubuntu 管理软件
  • win7系统怎样
  • 高效内存管理
  • 笔记本上安装软件怎么弄
  • 系统引导程序出错了如何修复
  • windows7壁纸怎么恢复
  • administrator帐户已锁定
  • linux修复工具
  • 如何将windows 10
  • Win10桌面版红石预览版14295更新(修复)、已知问题及解决方案汇总
  • javascript的理解
  • 生成0-100的随机数,直到生成88为止,停止循环
  • jquery插件使用教程
  • JQuery解析XML数据的几个简单实例
  • 安卓开发速成
  • Dalvik VM (DVM) 与Java VM (JVM)之间有哪些区别
  • 如何查看税务登记信息
  • 纳税人如何划分
  • 消费税的征收范围口诀
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设