数据库关联查询数据量大的地方做主表?还是数据量小的表做主表?哪一个效率更高呢?
数据库关联查询,(例如 left join)
数据量大的地方做主表?还是数据量小的表做主表?哪一个效率更高呢? 请说明!
例:
A表中有1000万条数据,B表中有1万条数据.
select * from A where id in (select id from B);
select * from B where id in (select id from A);
-------------------------------------------------------
select * from A left join B on A.id = B.id;
select * from B left join A on B.id = A.id;
-------------------------------------------------------
select * from A as AA,B as BB where AA.id = BB.id
-------------------------------------------------------
我用mysql 刚才试了一下.我现在是 大表有5W数据 小表有1.5W数据(两个表都没有做索引)
select * from A left join B on A.id = B.id;
查询差不多花费了50秒
select * from B left join A on A.id = B.id;
这种2秒
select * from A where id in (select id from B);
select * from B where id in (select id from A);
相当于 inner join 的情况
1.select * from A where id in (select id from B);
2.select * from B where id in (select id from A);
3.select * from A left join B on A.id = B.id;
4.select * from B left join A on B.id = A.id;
5.select * from A as AA,B as BB where AA.id = BB.id
数据少的做主表,而且你上面提供的5种查询方法中,只有第2种方法(数据量小的做主表)查询出来是正确的,其他查询出来都是错误的数据.
1,3,4三个方法都是把数据量大的表所有数据都查出来,5的方法是把数据量小的表的数据全部查出来
自己试一下最重要
a表有几十条索引,b表几条索引还有分区 a 表 728039 条 b表 8809883 条
(1)select count(1) from a a left join b b on a.id=b.id;----3.531 --3.188 --9284472
(2)select count(1) from a a left join b b on a.id=b.id; ----3.359 --1.609 --8809883
(3) select * from A as AA,B as BB where AA.id = BB.id ----3.062 --2.593 --8744249
(4) select * from A where id in (select id from B); --4.234 --3 --187816
(5) select * from B where id in (select id from A); --55.421 --2.657 --8744249
结果:
(1)select * 时长为3.531秒,count(1)时长为3.188 数据为9284472
(2)select * 时长为3.359秒,count(1)时长为1.609 数据为8809883
所以你还要根据你的业务来
- 等 最代码怎么获取牛币啊?
- 完 谁来告诉我最代码上线的时间,答对者给5牛币,先来先得
- 等 牛友们,大家好,你们做程序员多久了?现在还好吗?
- 完 在微信打开的页面里进行app下载
- 等 最代码2014年欢乐聚声会
- 完 mysql如何查询表数据并且对3个字段降序的SQL?
- 完 最代码牛币机制改革
- 完 成功的在bae上使用了自定义运行环境 jetty+nginx的组合,大家对jetty+nginx优化有哪些心得?
- 完 进来分享一下各位牛牛是如何加入最代码大家庭的?
- 等 为什么java BufferedImage类处理大图直接抛出内存溢出的异常?
- 等 最代码是否开发手机app客户端?
- 完 java程序员学习哪些java的技术?java有哪些框架?都能做哪方面的开发?
- 等 php格式网页文件怎么运行?
- 等 Java volatile值获取的问题
- 等 前端vue,拦截了登录后台后,返回的token,requests拦截token,但是发送请求的时候,就出现跨越异常
- 等 大专本科计算机科班怎么找到Java工作?
- 等 eclipse怎么把三个java swing游戏项目合成一个项目?
- 完 伙伴们,大家都有什么好的解压方式么,分享一下~
- 完 三四线城市,6、7k,运维工作,索然无味,想去辞职上培训,各位牛牛有什么建议嘛
- 等 jsp页面输入中文变成问号
- 等 JPA在线上运行一段时间后报错Caused by: java.lang.IncompatibleClassChangeError: null
- 等 PHP 这个规则用preg_match_all怎么写
- 等 大佬们,有没有知道Alfresco如何配置LDAP登录呢?
- 等 php的install目录是框架带的吗?