这段时间在做项目的过程中,遇到一个模块,数据之间的联系很复杂,在建表的时候就很纠结,到底该怎么去处理这些复杂的数据呢,是单表查询,然后在业务层去处理数据间的关系,还是直接通过多表连接查询来处理数据关系呢?

通过查阅资料和阅读博客,有以下两个回答:

一、《高性能mysql》中的回答

很多高性能的应用都会对关联查询进行分解。简单地,可以对每个表进行一次单表查询,然后将结果在应用程序中进行关联。例如,下面这个查询:

select * from tag

join tag_post on tag_post.tag_id=tag.id

join post on tag_post.post_id=post.id

where tag.tag=’mysql’;

可以分解成下面这些查询来代替:

Select * from tag where tag=’mysql’;

Select * from tag_post where tag_id=1234;

Select * from post where id in(123,456,567,9989,8909);

到底为什么要这样做?

咋一看,这样做并没有什么好处,原本一条查询,这里却变成了多条查询,返回结果又是一模一样。

事实上,用分解关联查询的方式重构查询具有如下优势:(高并发、高性能的应用中,一般建议使用单表查询)
1. 让缓存的效率更高。许多应用程序可以方便地缓存单表查询对应的结果对象。另外对于MySQL的查询缓存来说,如果关联中的某个表发生了变化,那么就无法使用查询缓存了,而拆分后,如果某个表很少改变,那么基于该表的查询就可以重复利用查询缓存结果了。

2. 将查询分解后,执行单个查询可以减少锁的竞争。

3. 在应用层做关联,可以更容易对数据库进行拆分,更容易做到高性能和可扩展。

4. 查询本身效率也可能会有所提升。

5. 可以减少冗余记录的查询。

6. 更进一步,这样做相当于在应用中实现了哈希关联,而不是使用MySQL的嵌套环关联,某些场景哈希关联的效率更高很多。

7. 单表查询有利于后期数据量大了分库分表,如果联合查询的话,一旦分库,原来的sql都需要改动。

8. 上次看到某个CTO技术分享,公司规定底层禁止用join联合查询。数据大的时候确实慢。

9. 联合查询或许确实快,但是mysql的资源通常比程序代码的资源紧张的多。

二、其他的一些回答

情景假设:假设网站有一个公司库版块,我想搜索某城市的所有公司。

数据表:tbl_company (t1)、 tbl_city (t2)。

例1: t1表中存cityid 根据id做表连接查询 select * from t1 inner join t2 on t1.cityid=t2.cityid;

例2: t1表中存cityName 用户前台点击上海市,则把上海市的id传到后台(不考虑传cityName),根据id查出cityName select cityName from t2 where cityid= #{cityid};, 然后 select * from t1 where cityName = #{cityName};

两者区别:例1中只做了一次表关联查询,例2中分别做了两次单表查询。

考虑到数据量大,多表连接查询会影响查询效率所以都优化为单表查询。 TP:以上是在不使用索引的情况下

请问哪种效率会更高些?

答:sql优化与业务也有关系,这条语句的查询会不会频繁,要不要考虑2次连接带来的开销,如果这些都不用考虑的话,都没有索引的情况下,感觉相差不大,2应该略优于1。

数据没有特别大的情况还是级联查询快。

对于传统的数据库涉及来说, 尽可能减少数据库查询次数.

BUT, 1. mysql都对处理连接/断开连接, 回复小而简单的 查询是非常快的; 2.现在的网络已经非常快了. 所以多个小的查询对mysql来说可能更快一些.

最后, 大神也没有结论哪个更好. 呵呵, 其实整本书都明确表达一个意思, 测试测试! 做benchmark! 对于自己的数据环境, 把两种方式都测试一下. 用数据说话.

三、总结

个人建议还是用单表查询!在应用层做数据之间的关联会更好!

单表查询和多表连接查询哪个效率更快?相关推荐

  1. SQL多表查询:SQL JOIN连接查询各种用法总结

    在实际应用中,大多的查询都是需要多表连接查询的,但很多初学SQL的小伙伴总对各种JOIN有些迷糊.回想一下,初期很长一段时间,我常用的似乎也就是等值连接 WHERE 后面加等号,对各种JOIN也是不求 ...

  2. 小白 MySQL数据库链接查询语句_MySQL数据库——连接查询

    今天将用 "手" 来教大家关于MySQL连接查询的知识! ============================================================= ...

  3. mysql 连接查询两个条件_MySQL之多表查询一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习...

    一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都会建一个数据库,那数据库里面是不是存了好多张表啊,不可能把所有的数据都放到一张表里面,肯定要分表来存数据,这样节 ...

  4. 关于连接查询主要是左右连接查询中,where和on的区别

    工作中,今天用到左连接查询,我自己造的数据,需要根据条件进行筛选,但是筛选不符合我的要求,最终发现是左右连接中where和on的区别,在作怪,工作中用的表关联太多,我下面简化要点,仅仅把注意点写个简单 ...

  5. MySQL查询的进阶操作--连接查询

    目录 概念 连接查询: 含义: 又称多表查询,当查询的字段来自于多个表时,就会用到连接查询.笛卡尔积乘积现象: 表1 有m行,表2 有n行,结果=m*n行. 发生的原因:没有有效的连接条件. 如何避免 ...

  6. mysql数据库(排序,聚合函数,分组,分页查询,union,连接查询,主键外键)

    1.排序(order by) select * from stu order by age; -- 默认升序 升序 ASC 降序DESC -- DESC 具有查看表的结构的功能 desc stu; 不 ...

  7. SQL service基础(四)连接查询、自身连接查询、外连接查询和复合条件连接查询

    实验目标: 1.掌握涉及一个以上数据表的查询方法. 2.掌握等值连接 3.掌握自然连接 4.掌握非等值连接 5.掌握自身连接.外连接和复合条件连接 本次实验sql脚本: INSERT [dbo].[T ...

  8. mysql 连接查询索引_Mysql (四)连接查询和索引

    一.什么是连接查询:就是将二个或二个以上的表,"连接起来"当做一个数据源,并从中去取得所须要的数据.连接查询包括交叉连接查询.内连接查询.外连接查询 (一)交叉连接:交叉连接不带W ...

  9. mysql连接与嵌套查询_数据库的连接查询和嵌套查询怎么做啊?

    4. select 订货单号,进货量 from 商品表,订货表 where 商品表.商品编号=订货表.商品编号 and 商品名称='螺母' 5. select 订货单号,进货价格 from 商品表,订 ...

最新文章

  1. DataGridView的单元格控制只能输入数字
  2. [MATLAB粒子模拟笔记]初始化半个时间步的位置
  3. 微信h5网页关闭分享以及关闭当前页面
  4. Gazebo仿真平台
  5. 【连载】如何掌握openGauss数据库核心技术?秘诀五:拿捏数据库安全(2)
  6. 计算机组成原理(第3版)唐朔飞著 知识点总结
  7. 获取CPU序列号的Delphi程序
  8. 用C语言编写一个关机程序
  9. 腾讯云服务器登录宝塔面板
  10. 网络 计算机 访问权限,电脑无网络访问权限如何解决
  11. My Fifty-fifth Page - 子集 - By Nicolas
  12. 服务器背板作用,硬盘和服务器背板
  13. 网站被劫持怎么办?别着急看完这篇文章您就知道如何应对了!
  14. 微信红包和转账有哪些区别?原来还有这些不同!涨知识了
  15. 高质量程序设计指南C++学习总结二
  16. getApplicationContext 详解
  17. 英语学习——逻辑之道
  18. 计算机上网的用户账号怎么查询,自己的宽带账号怎么查
  19. 2023年Java面试题_MySQL
  20. 从客户端中检测到有潜在危险的 request.form值[解决方法]

热门文章

  1. TYPE-C和USB-C接口有什么区别?
  2. linux动态库的查找顺序
  3. SQL Server 锁升级
  4. braintree php,magento2 Braintree payment如何使用?
  5. 2019年演出经纪人考试报名 《政策法规及经纪实务》《舞台艺术基础知识》两个科目学习资料
  6. JSP汽车维修服务管理系统myeclipse开发SqlServer数据库bs框架java编程web网页结构
  7. Oracle ERP 技术探讨
  8. 十、children的深入用法-React.Children对象上的方法
  9. Js-parentNode、parentElement,childNodes、children 的区别
  10. 随机过程笔记(5) 平稳过程